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DSD: The System Display 
Introduction 

The display console is controlled by a display program, DSD, which 
permanently resi-des in peripheral processor 9. DSD displays a variety 
of information concerning the status of the system, including a display 
of the dayfile, a display of the jobs waiting to be executed and waiting 
to be printed, and a display showing the status of each control point. 
DSD permits selected portions of central memory to be displayed, and 
also provides for the modification of central memory locations. 
In addition to its display function, DSD processes keyboard messages 
from the operator. Operator functions include bringing a job to or 
dropping a job from a control point, assigning equipment, and selection 
of various types of displays. The Chippewa Operating System also 
contains a job display package, DIS. DIS, when called, is assigned to a 
control point, and permits the modification of job parameters, memory 
locations, and control statement sequences for this job assigned to the 
control point. For the most part, DSD and DIS displays are identical. 

The main components of the display console are the two cathode ray tubes 
and the keyboard. By issuing the appropriate function codes to the 
display console controller, displays of 16, 32, or 64 characters per 
line may be selected on either the right or left screens. A dot mode 
display is also available, although only the character mode display is 
used by the operating system. The display area can be considered to be 
composed of a grid of points, 512 by 512 points in size. A display can 
be initiated at any point in the display area by issuing the coordinates 
of that point. A vertical, or Y, coordinate is sent to the controller 
in the low-order nine bits of a byte in which the high-order octal digit 
is a 7. Similarly, a horizontal, or X, coordinate is sent to the controller 
in the low-order nine bits of a byte in which the high-order octal digit 
is a 6. If the display console controller receives a byte in which the 
high-order octal digit is. neither a 6 or a 7, it is assumed that this 
byte contains two display code characters. 

To display a line of information on the screen, an X and a Y coordinate 
are sent to the controller via the appropriate output instructions 



(OAN or 0AM). These coordinates define the location of the lower lef t ' 

corner of the first character to be displayed. The information to be 

displayed is then sent to the controller via an 0AM instruction. As 

each character is displayed the X coordinate is automatically incremented. 

To display another line, the X and Y coordinates should be reinitialized. 

A coordinate of X=000 defines the left-most boundary of the display area; 

a coordinate of X=777o defines the right-most boundary of the display 

o 
area; a coordinate of Y=777g defines the upper boundary of the display 

area, and a coordinate of Y=000 defines the lower boundary of the display 



area. 



The Chippewa Operating System uses a display of 64 characters per line 
in both DSD and DIS. Generally, the Y (vertical) coordinate spacing 
between successive lines is 12g. The display must be regenerated at 
least 25 times p_er second in order to avoid flicker. The DSD display 
is designed to maintain an average rate of 40 displays per second. 

DSD Master Loop 

The DSD master loop is shown on page A-1 of the attached flow charts. 
On the initial entry to this routine (i.e., at dead start time), a 
subroutine is called to perform housekeeping. This subroutine clears 
the temporary storage areas used by DSD, selects the "A" display 
(dayfile) on the left screen and the "B" display (control points) on 
the right screen, and requests reservation of channel 10 from MTR. 
Display selection in DSD is performed by setting the address of the 
desired display subroutine in location 70 for the left screen and in 
location 71 for the right screen. 

On each pass through its master loop, DSD selects the display console 
keyboard and issues an input instruction to read the keyboard. If a 
zero byte is returned, then no key has been depressed since the last 
pass through the master loop. If a non-zero byte is returned, the key- 
board character in the low-order bits of the byte is processed. If the 
character is a carriage return, the Message Ready flag is set and the 
keyboard message is processed. 



After keyboard processing is completed, DSD issues a function code to • 
select the left screen, and displays the time and date from central 
memory resident beginning at location 30. The contents of this area are 
read and displayed, word by word, until a zero byte is encountered. 
Regardless of the display selected for the left screen, the time-date 
line is always displayed. DQp then jumps to the subroutine whose address 
is contained in location 70 to process the selected left screen display. 
At the bottom of the left screen, the keyboard message currently being 
entered is displayed. If an error is encountered in processing this 
message, the error message "FORMAT ERROR" will be displayed immediately 
above, the keyboard message. Once processing of a valid message is com- 
plete, the message will be no longer displayed. 

DSD then issues a function code to display the right screen. At the top 
of the right screen, the contents of the central processor P register 
and the status of the 12 data channels are always displayed. DSD reads 
the central processor P register, converts the contents of the P register 
to display code, and displays these characters. On the same line, three 
groups of four characters, one character for each of the 12 data channels., 
are displayed. Each channel is first tested to determine if it is active 
or inactive. If the channel is inactive, the displayed character cor- 
responding to that channel is a "D" (disconnected). If the channel is 
active and empty, an "E" is displayed, while if the channel is active 
and full, an "F" is displayed. (See figure 1) DSD then jumps to the 
subroutine whose address is contained in location 71 to process the 
selected right screen display. 

After both screens have been displayed, DSD calls the Adjust Display 
Period subroutine (shown on page A-1 of the attached flow charts). The 
purpose of this subroutine is to control the number of passes made through 
DSD's master loop in a fixed time interval in order to avoid flicker. 
On each entry to the Adjust Display Period subroutine (i.e., on each 
pass through DSD's master loop), a display cycle counter is advanced. 
At the end of each second, the display cycle count is examined to determine 
if the display was repeated more than 50g times in the past second. 
If it was, a delay count (D) equal to the display cycle count - 50g is 
set. If the display was repeated less than 50 times in the past second, 
this delay count is set to zero. The delay count is used to establish 
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Figure 1 



a delay between successive passes through DSD's master loop: the larger 

the delay, the greater the time between successive passes through the 

master loop. Also, in the next second, D will be set to zero if the 

display is repeated 50-D times or less. If in any second, then, the 

display is repeated more than SOq times, a delay so that the display will 

o 

be repeated less than SOq times in the subsequent second: over a period 
of several seconds, the display rate should average out to 50_ times per 

• o 

second. At the end of each secon.d, the display cycle counter is reset 
to zero. 1 

In a 6000 system with a single display console, DSD must relinquish control 
to DIS when the latter is called to a control point. When DIS begins 
execution, it requests MTR to assign an equipment of type DS. MTR 
searches the EST for an entry of this type, and, when found, enters the 
requestor's control point address in byte one of the EST entry. On 
each pass through its master loop, DSD reads the EST entry for equip- 
ment number 10. If byte one is non-zero, then this equipment has been 
assigned to another user - DIS. DSD then releases the channel reservation 
for the channel to which the display controller is connected, and loops 
on a test of byte one of the EST entry. When this byte becomes zero 
once again, DIS has released control of the console, and so DSD requests 
the channel once again and returns to its master loop. 

One of the keyboard entries processed by DSD is the "STEP." message, 
which causes MTR to enter a step mode of operation. In step mode, MTR 
pauses for operation intervention before processing each request from 
a peripheral processor. To process the STEP message, DSD sends function 
request 5 to MTR. MTR then sets a switch in the subroutine which 
processes requests from peripheral processors. When a request is next 
received from a peripheral' processor, MTR will set a Wait flag in byte 
5 of central memory location 14, and will then loop until this flag has 
been modified. Entering a space on the keyboard will result in the 
clearing of this flag by DSD: MTR will then process the request just 
received, but will pause again before processing subsequent requests. 
Entering a period on the keyboard will result in this flag's being set to 
7777 by DSD: MTR will then reset the switch in the subroutine which 
processes peripheral processor requests, and will process subsequent 
requests in the normal manner. Since a space or a period is not, in 
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itself, a conventional DSD message, DSD checks for the entry of these 
characters on each pass through its master loop if MTR is in step mode. 

DSD Keyboard Message Processing 

The processing of characters received from the keyboard is shown in 
the flow chart on page A-1. If the character received is a carriage 
return, then a complete message has been entered and so the Message Ready 
flag is set. If the character received is a backspace, DSD clears the 
last character entered in the buffer, resets the buffer address accordingly, 
and clears the error flag which may have been set if an attempt was made 
to process the message. If the drop key was depressed, then the entire 
message is deleted: the buffer address is reset to the starting address, 
and the error flag cleared. Should the character be a valid keyboard 
character, it is entered in the message buffer. and the buffer address 
advanced. Note that the space character from the keyboard (62 ) is not 
a display code character, and so a blank (55n) is substituted for it. 

When DSD detects that a carriage return has been entered on the keyboard, 
the Message Ready flag is set to indicate that a message is ready for 
processing. DSD then proceeds to interpret the message. Message 
processing is illustrated in the flow chart. on page A-2. The second 
character is examined to determine if it is a period: if it is, then the 
message is a control point message, and so the first character is examined 
to determine if it is a valid control point number (1-7). If the first 
character is not a numeric in the range 1-7, the Message Error flag is 
set and control returned to DSD's master loop, where the message "FORMAT 
ERROR" will be displayed. If the first character is a valid control 
point number, then a table search is made for the address of the appropriate 
subroutine. If the message is not found in the table, the Message Error 
flag is set and control is returned to DSD's master loop. Processing of 
the valid control point messages is described below. 

ONSW: If the message is of the form. n.ONSWx., DSD sets the bit 
corresponding to X+5 in byte 5 of location RA for control point n, 
and in word 26 of control point area n. Control is then returned 
to DSD's master loop. 
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OFFSW: If the message is of the form n.OFFS^fe., DSD clears the 
bit corresponding to X+5 in byte 5 of location RA for control 
point n, and in word 26 of control point area n. Control is then 
returned to DSD's master loop. 

LOAD ; If the message is of the form n.LOAD., DSD writes the package 
name (ILT) and the control point number, n, in its Message Buffer, 
Word 21 of control point area n is then examined to determine if the 
control point area contains a job name. If it does not, DSD requests 
MTR to assign a pool processor to control point n. MTR will copy 
the contents of DSD's Message Buffer into the Input Register of a 
free pool processor, and assign the processor to control point n. 
Control is then returned to DSD's master loop. If the control 
point area contains a job name (word 21 non-zero), control is 
returned to the DSD master loop. If the control point area contains 
a job name (word 21 non-zero), control is returned to the DSD master 
loop without requesting the assignment of a processor. 

NEXT : Processing of the message n.NEXT. is identical to the pro- 
cessing of the LOAD message with the exception that the package name 
IBJ is written in DSD's Message Buffer. 

READ: Processing of the message n.READ. is identical to the pro- 
cessing of the LOAD message with the exception that the package 
name lU is written in DSD's Message Buffer. 

PRINT: Processing of the message n. PRINT, is identical to the pro- 
cessing of the LOAD message with the exception that the package 
name IDJ is written In DSD's Message Buffer. 

PIS : If the message is of the form n.DIS., DSD writes the package 
name DIS in its Message Buffer, and requests MTR to assign a pool 
processor to control point n. Control is then returned to DSD's 
master loop. 

ASSIGN : The ASSIGN message is generally entered in response to a 
REQUEST statement display or the message WAITING FOR XX. If the 
message is of the form n.ASSIGNXX., DSD requests MTR to assign the 

-7- 



specified equipment to the control point. MTR looks up the 
corresponding entry in the EST: if equipment XX is not already 
assigned, then MTR assigns the equipment to control point n and 
writes the equipment number in word 22 in the control point area. 
After initiating the MTR request, control is returned to DSD's 
master loop. 

GO: The 1^ bit in byte 4 of location RA is a pause bit. This bit 
is. set by a FORTRAN PAUSE statement, and is also set by certain 
peripheral packages when an error is detected. For example, 2RT 
sets this bit when a parity error has occurred after reading a 
record three times. When the n.GO. statement is processed, this 
bit is cleared. Also, the most recent message in the control 
point area (presumably the PAUSE statement) is cleared. 

END: If the message is of the form n.ENDl., n.END2., n.END3., 
or n.END4., DSD sets a printer stop code in byte 2 of word 20 in 
the control point area. This stop code is equivalent to setting 
the low-order second octal digit of this byte to the digit following 
the word END in the message. The printer stop code is sensed by 
the four-printer print programs. 

DROP ; If the message is of the form n.DROP., DSD writes the control 
point number n in its Output Register, and requests MTR to drop 
the job at control point n. MTR sets error flag six (Operator 
Drop) to initiate error processing. 

If the second character in the message was a period, and the message was 
not found to be one of those described above, the Message Error flag is 
set and control returned to DSD's master loop. If the second character 
in the message was not a period, the first character is examined to 
determine if it is an octal digit. Should the first character be an 
octal digit, it is assumed that the message is a storage entry message of 
the form a,d., where a represents a central memory address and d represents 
the data to be entered in memory at that address. The characters in 
the message are assembled and converted to octal until a separator is 
found: if the separator is not a comma, the Message Error flag is set. 
Once the address has been assembled, the characters following the comma 
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are assembled and converted to octal until another separator is found. 
If this separator is not a period, the Message Error flag is set. The 
assembled data is stored, right-justified, in a 5-byte area, and the 
contents of this area are then written in central memory at the specified 
address , 

If the first character is not an octal digit, the third character is 
examined to determine if it is a period. If the third character is a 
period, the message is assumed to be a display mode message of the form 
AB., where A and B represent characters specifying the desired display 
on the left and right screens respectively. The subroutine address 
corresponding to the specified display (A-H) is located in a table and 
stored in location 70, in the case of the left screen display, or 
location 71, in the case of the right screen display. 

If the third character was not a period but was a comma, it is assumed 

that the message is a display field change message of the form mf,a., 

where m is the display mode (C-G), A is the field whose starting address 

is to be changed (0-3 for fields 0-3, or 4 for all four fields), and a 

is the new starting address. Each of the storage display subroutines for 

storage displays C, D, E, F, and G maintains a list of four addresses, 

one for each of the four fields displayed. When this message is detected, 

DSD modifies the appropriate address in the list of field addresses for 

the specified display if the second character is 0-3. If the second 

character of the message is 4, the first address in the list is set to 

the address contained in the message, the second address in the list 

is set to the address contained in the message plus IOq, and so forth. 

o 

If the third character in the message is not a comma, it is assumed to 
be a non-control point message of the form described below. DSD searches 
a table for the address of the appropriate subroutine: if the message 
is not found in the table, the Message Error flag is' set and control 
returned to DSD's master loop. Processing of these messages is described 
below. 

DCN: If the message is of the form DCNXX., where XX is an octal 
channel number, DSD assembles the channel number and_ tests the 
channel to determine if it is inactive. If the channel is active, 
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a channel disconnect is issued. 

FCN ; If the message is of the form FCNXX., where X is an octal 
channel number, the channel number is assembled and a testmade to 
determine if the channel is inactive. If the channel is inactive, 
a zero function is sent to the channel. 

AUTO : If the message is AUTO., DSD assigns READ (lU) to control 
point 1, PRINT (IDJ) to control point 2, and NEXT (IBJ) to control 
points 3, 4, 5, and 6. To assign a package to a control point, 
DSD writes the package name and control point number in bytes one 
and two of word one of its Message Buffer, and s^nds function 
request 20, Assign FPU, to MTR. MTR locates a free pool processor, 
assigns it to the control point, and copies word one of DSD's 
Message Buffer into the pool processor's Input Register. 

STEP : If the message is STEP., DSD requests MTR to enter step 
mode by sending function request 5 to MTR. (See discussion on 
page 5.) 

ON or OFF ; The messages ONXX" and OFFXX. permit the operator to 
clear and set, respectively, the interlock bit in the EST table 
entries. In these messages, XX is an octal equipment number which 
defines a location in EST. The interlock bit is generally used 
only with magnetic tape units. When this bit is set, the corresponding 
equipment will not be automatically allocated in response to an 
ASSIGN request: if this bit is cleared, and a request such as 
ASSIGN MT is processed, the equipment will be automatically assigned 
by MTR. For equipment types MT and WT, this bit is set at load 
time. (See page 9 of CENTRAL MEMORY RESIDENT.) 

TIME : If the message begins with the characters TIME., and 
contents of the keyboard message buffer following these characters 
are copied into central memory resident beginning at location 30.. 
This information may comprise up to six central memory words. It 
is assumed that the first portion of this message has the form _HR.MN. 
SC, where HR represents hours, MN represents minutes, and SC 
represents seconds. This time will be advanced by MTR and will 
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appear in all dayfile messages and at the top of the left screen 
display. The information following the time may be the "date and/or 
any other desired information. The date portion will also be 
displayed at the top of the left screen, and will be printed at 
the end of a job's dayfile listing. 

DSD Displays 

The various display modes which may be selected in DSD are as follows: 

A Dayfile Display 

B Control Point Display 

C Storage Display (5 groups of 4 digits) 

D Storage Display (5 groups of 4 digits) 

E Storage Display (5 groups of 4 digits) 

F Storage Display (4 groups of 5 digits) 

G Storage Display (4 groups of 5 digits) 

H Job Backlog Display 

The format of these displays is illustrated in figures 2, 3, and 4. 
Each display is processed by a separate DSD subroutine: these sub- 
routines appear on pages A-3 and A-4 of the attached flow charts. 
For the most part, display processing is quite straightforward, and 
discussions of these displays will be limited to points of interest. 

"A" Display : The "A" display is a display of the dayfile buffer 
(DFB) contents from FIRST to IN. It is possible that the bottom 
of the display area may be reached before all the information in 
the dayfile has been displayed. If so, the subroutine parameters 
are modified so that on the next entry to . the subroutine, the 
message which previously appeared at the top of the display will not 
be processed, thus permitting a new message to be displayed. Also, 
the point at which the display begins is moved down by the width of 
a line, and gradually moved back up during the next 10 displays. 
As a result, a revolving or rolling effect is obtained. 

"B" Display : The B display shows information concerning each of the 
seven control points, as shown in figure 3. On entry to this 
subroutine, the copy of the control stack which MTR maintains in 
locations 56-57 of central memory resident is read. For each control 

-11- 




o 



< 
o 

•-3 



M 
Q 




M 



a 






31 

a, 
to 

5 



Figure 2 



-12- 










U 








O 








< 








M 








M 








W 


\ 






23 


^ 






W 


1 






hJ 


H 






M 


2 


W 




b 


bJ 


to 




>-l 


2 


w . 




< 


On 


CU 




Q 


M 


Q 






3- 


Q 


H 




u 




O 


O 




W 


2 


cn 


o 


o 


W 


z 


w 


z 


►J 


o 


2 


u 




o 


o 


oi 


Q 




M 


Cd 


hJ 


H 


M 


fa 


Cd 


W 


CO 


Pi 


M 


d 




o 

0. 



o 

O 

-J 
a. 

5 

CD 

tn 



-13- 



Pigure 3 



point in the stack, a status indicator, A-G, is set to represent 
the position of that control point in the stack (i.e., A represents 
the top of the stack, B the second entry in the stack, and so forth). 
The status byte in each control point is also read, and the status 
indicator set to W or X depending on the setting of these flags. 
The remaining processing performed by the subroutine consists of 
reading information from the control point area and displaying 
this information. 

Displays C-G : The storage displays, C through G, each display 4 
fields of 8 central memory words (see figure 4). Displays C, D, 
E are identical in format and display each central memory word as 
5 groups of 4 octal digits. Displays F and G are identical in 
format and display each central memory word as 4 groups of 5 octal 
digits. There is a separate subroutine for each of these five 
displays: each of these subroutines maintains a list of four field 
addresses which specify the starting point for each of the four 
8-word field displays. These address lists are set via keyboard 
messages (see page 9). The address lists are initialized at load 
time as follows: 

C Display Words 20-27 of control point areas 1, 2, 3, and 4 

D Display .....CM resident locations 0-37 

E Display .....CM resident locations 60-117 

F Display .....Central Memory locations 10000-10037 

G Display .....Central Memory locations 10040-10077 

The reason for identical displays (C, D, E, and F, G) is to permit 
the operation to switch between scans of selected memory areas 
without the necessity of entering starting addresses each time he 
switches from one area to another. 

"H" Display : The H display lists the input and output files in the 
FNT. Upon entry to the H display subroutine, the FNT is searched 
and two lists prepared: one, a list of FNT addresses for entries 
of file type INPUT, and the other a list of FNT addresses for 
entries of file type OUTPUT. The entries represented in these lists 
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are then read, and the file name and priority displayed. These 

lists are updated only at intervals of 1/10 of a second in order 
to reduce unnecessary read pyramid conflicts. 
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OPERATIONS 



(1) 



DIS JOB DISPLAY 



INTRODUCTION 



DIS is the name of the Chippewa Operating Sysucm peripheral 
program that monitors console - keyboard activity for a 
job assigned to a particular control point. DIS must be 
loaded in as many PPU units as the number of control points 
for which it is required. The package is usually located 
on the system disk in the peripheral library; therefore, 
its name will appear in the PLD (Peripheral Library Direct- 
ory) . DIS may be brought to a control point in any one 
of three ways: 

1. Typing "A. DIS CR" when DSD (system display) is active. 

2. Inserting a DIS control card. 

3. A central memory program requesting DIS through a call 
to MSG. 

DIS is concerned with the following functions: 

• Job Displays 

• Monitoring Keyboard Activity 

• Processing Requests for job control debugging for only 
the job assigned to its control point. 

DIS operates during the time the job to which it is attached 
has the control point. If it is desired to manually re- 
lease DIS, a drop request is made, which in turn causes " 
a drop PPUs to be issued by the PPU containing DIS. DIS 
would have to again be loaded for future use by this con- 
trol point. If an error condition (error byte becomes non- 
zero in CP area) the program will drop itself; a check of 
this nature is msde on each iteration through the master 
control .loop. 



CONSOLE DISPLAY 



One of the prime functions of DIS is displaying informa- 
tion concerning the status of the job at the control point 
to which it is attached. To do this, DIS outputs informa- 
tion in the form of display coded characters (see SIPROS 
DEF Manual) and necessitates issuing X and Y coordinate 
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values followed by the string of 6-bit display coda char- 
acters. The screen of each CRT may be considered a grid 
of . points as follows: 



X=6000 
Y=7777 




X=6777 
Y=7777 



X=6000 
Y=7000 



X=6777 
Y=7000 



Figure 1 

The coordinates (x=6xxx, Y=7xxx) specify the position of 
the first display coded character follow. Thereafter, 
the X coordinate is advanced (by one character space) 
along the increasing x axis but the y coordinate remains 
constant until another y coordinate (7xxx) is issued. 
For example, the dayfile display program in DSD uses the 
area 7200 to 7660 and form 6000 to 6777. 
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In the dayfile display, the y coordinate is allowed to 
increase by +1, from 7646 to 7660 on each cycle of the mas- 
ter control .loop. As will be seen, this has the effect of 
"rolling" the display upwards on the screen. The use of 
the console display is quite simple, involving only .the 
outputing of appropriate x and y coordinates followed by 
the display coded string of characters. 

Besides the formation of display characters and screen 
positioning, the program also controls the brightness 
(or intensity) of the image on the screen. The latter 
increases in proportion to the number of times per second 
the display coded information is presented to the console. 
To maintain a stable visable image, the code must be out- 
put to the console at least every 1/25 of a second. More 
repetitions per second will produce a brighter image. A 
delay loop is commonly employed to control the image out- 
put period. 

Example of display loop: 



LOOP 



DELAY 



IJM 


*+3, lOB 


DCN 


lOB 


FNC 


7001R,10B 


ACN 


1GB 


LDC 


7000B 


OAN 


lOB 


LDC 


6337B 


OAC 


lOB 


LDC 


16 


OAM 


Buffer^-OB 


LDN 


GIB 


SHN 


9 


SBN 


1 


PJN 


Delay 


LJM 


Loop 



•Jump if channel lOB inactive 
.Disconnect channel lOB 
.Select 32 Char/Line left screen 
•Activate channel 
■ .A= Y coordinate 
.Output Y coordinate 
.A= X coordinate 
.Output X coordinate 
.A= No. Words to output 
.Output from buffer 
.Set A= No. milliseconds delay .. 
.Convert for LOOP 
.2 us delay loop 

.End of millisecond loop. 
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The logic in DIS which controls console output is not 
basically different from the above example. The overall 
scheme can be visualized as follows: 




Figure 4 

To maintain the delay function, a parameter may be in- 
serted into the ADJUST DISPLAY PERIOD and PRESET INITIAL 
VALUES ROUTINES. It has the form: LDN nn, where nn is 
the number of milliseconds (from 00 to 47„) in the delay. 
For maximum brightness, this is preset to nn=00j it can 
■be modified, however. Since other operations (keyboard 
monitoring) take place in DIS, this constant also effects 
the total sensitivity of the whole system. For normal 
operations, it is not necessary to alter this constant. 
Notice in figure 4 the image is established through contin- 
uous trips around the display loop. 



KEYBOARD 



Along with the display screens at the console unit is a 
typewrite- like keyboard containing keys for alphabetic, 
numeric and special characters. These, in display code, 
are listed on page 46 of the manual on CODES for the 6000 
Computer System. Keys are also present for the following 
special purposes: 
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KEY DISPLAY CODE 

Carriage Return (CR) 60g 

Backspace 61. 

Space 62g 

These keys are used by the KevlBOARD MONITORING routine to 
control the proper filling of the KB (keyboard) assembly 
buffer (location 1300/1377 in DIS) . A CR is interpreted 
by DIS as an end of message. The backspace key will erase 
the last character input. The drop key (code 55) will 
cause the string of characters of the current message, in- 
put to that time, to be cleared; the next character keyed 
will be treated as the first of a new message. 

When it is desired to interrogate the keyboard for keyed 
information, an input to A is given. Xf there was a char- 
acter keyed, 'the console unit c©ntroller will return the 
character, in display code, in the lower 6 bits of a 12- 
bit byte (the high order 6 bits are cleared to 00) . If 
no key was activated, however, the controller will return 
an all zero 12-bit byte. 

On each cycle of the Master Control Loop, DIS examines the 
data at the keyboard. If a valid character is input, the 
byte is stored away in a contiguous manner in the KB . 
assembly buffer. A cleared byte (0000) 

will cause no data to be stored. Appropriate action is 
taken when the CR, backspace or drop key is activated. 
When a CR is recognized, a flag, called the keyset Ready 
flag is set to 0001; representing the "on" condition. This 
flag is examined once during each control cycle. If not 
set (0000) no action is taken; if set (0001), however, the 
message in the KB Assembly buffer is interpreted, processed 
and the' flag reset to 0000. 

Figure 5 illustrates the position of the keyboard process- 
ing in the control sequence of DIS (see figure 4 also): 
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MASTER CONTROL Figure 5 combines several of the functions which make up 

PROGRAM , . , 

the MCP (MASTER CONTROL PROGRAM) : 

'Keyboard Monitoring 
•Request Processing initiation 
'Left Screen Display 
■Right Screen Display 
'Display Period Adjustment 

Only a few more functions need to be added to produce the 
operations performed by the MCP. Regardless of the dis- 
play mode selected (A, B, ..., G) there are permanent dis- 
plays on both the left and right screens. On the left ap- 
pears the time and date line stored in Central Memory lo- 
cations 30/37; this is displayed at Y coordinate 7700. 
At Y coordinates 7100 and 7066 are the error message (if 
any) and the contents of the KB Assembly Buffer (at that 
point in time), respectively. The current Central Pro- 
cessor Prregister and the status of all 12 data channels 
are displayed at Y coordinate 7700 on the right screen. 
In the functional diagram (figure 5) these displays may 
be thought of as belonging to the left and right screen 
displays. 

One function remains: breakpoint monitoring. The user 
is given the opportunity to request (via the keyboard) a 
breakpoint debugging action. This routine reads the CP' B 
register and if the contents match the requested breakpoint 
address (in P 52/53) the Central Processor is dropped from 
the control point and the word at the breakpoint (saved 
in P40/144 during breakpoint initiation) is restored in 
CM. This function follows the display period adjustment 
routine. All functions of the MCP are 'Illustrated in de- 
tail in MCP flow chart (see appendix A) . 
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DISPLAY PROGRAMS 



DIS is able to provide four different types (modes) of 
displays. This operations indicated in the two circles in 
Figure 5 refer to the particular display and its assoc- 
iated display program selected for that screen for dis- 
cussion purposes. The permanent displays were considered 
here as well. Initially, DIS will put up the dayfile 
display on the left screen and the job status infor 
on the right. These can be altered, if desired, by key- 
ing the following request. 



LR. "CR" 

The mode code placed in the L position will bring the dis- 
play for that code to the left screen and one placed in R 
will specify the right screen display. The address for 
the left and right screen programs are stored in locations 
70 and 71, respectively. 



DISPLAY MODES 



CODE 



A 






B 






c. 


D, 


E 


F, 


G 





DISPLAY INFORMATION 
Day File 
Job Status 
Program Storage 
Data Storage 



Day File Display - MODE A 

This program displays the contents of the DFB (Day File 
Buffer) between Y coordinates 7660 (top) to 7200 (bottom) 
This coordinate is stored in location 64. The most cur- 
rent being displayed message will always appear at the 
bottom of the display. Up to 3/10 messages can appear be- 
tween these limits. After each message is displayed, the 

Y coordinate is decremented by 12q. 

8 

A' pointer in location 65' is maintained to indicate the ad- 
dress of the DFB message to be displayed at the top of 
the display. Initially this pointer equals the "OUT" ad- 
dress of the DFB status word (CM location 0003) ; this is 
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advanced as the number messages between the current address 
(at 65) and the "INPUT" address exceeds 31^- . When 31 or 
fewer DFB messages are between (65) and "INPUT',' the display 
stays constant with new messages being displayed at the 
bottom of the display as they appear in the DFB. 

If, however, the number of messages in the DFB exceeds the 
maximum number that can be processed at one time, the dis- 
play will not remain fixed. Rather, it will "roll up" on 
the face of the screen. This gives the impression that 
when the message now at the head of the display reaches 
the top it is rolled off the screen and a new (and more 
current) message enters the display at the bottom. This 
will continue until the number of DFB messages between 
the address stored in 65 and the INPUT DFB status indica- 
tor becomes less than 31. This rolling is accomplished 
by allowing the beginning Y coordinate to vary from 7646 
to 7660 (in increments of 1) on each cycle of the DIS mas- 
ter control loop. Therefore, 12„ iterations will be 
necessary to roll off a message. As each message is rolled 
off the screen, the DFB pointer in 65 is advanced to the 
address of the next message in the DFB. All display ref- 
erences are made relative to this address. Eg: if 65 
contained 2334 then the first (top most) message would be 
picked up from the CM location 002334. Then the next 30 
messages (not the next 30 cells) to be displayed will be 
picked up. When the message beginning at CM 002334 is 
rolled off the display, the address in 65 will be set to 
point to the first word of the next DFB message. If the 
message at CM 002334 is three cells long, 65 will be set 
equal to 002337. Whenever a message is rolled off, the Y 
coordinate is reset equal to 7646. See the flow chart in 
Appendix A, A-39 for a detailed description of the process. 

Job Status Display - MODE B 

This display exhibits the control point status. (W, X, A, 

.....G, -), last dayfile message the next control state- 
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merit to be processed and the exchange jump package. This 
information is gathered from the control point area . 

Storage Displays - MODES C, D, E, F, G 

Modes C, D, E are primarily used to display program text 
residing within Central Memory. These form display octal 
digits in the form of 4 groups of 5 digits each. 

Modes F, G, in contrast, display octal digits in 5 groups 
of 4 digits. These coorespond to the 12~bit PPU words and 
hence modes F, G are used for data storage. 

Besides the above differences, the five modes all share 
these characteristics. All displays have four fields. 
A field is the display of the eight words XXXXXO - XXXXX7. 
The particular field specification is given by the typed 
statement: 

Xn, m. "CR" 
where X = C, D, E, F, G 

n = Field begins with m 

1 Field 1 begins with m 

2 Field 2 begins with m 

3 Field 3 begins with m 

4 Four consecutive field beginning with m. 

m = Central memory relative (to RA) address. 
This should be of the form XXXXXO. In any 
case, the low order digits is made if any 
other digit is specified. 

Eg: 1. C2,330. "CR" would set field 2 beginning address 

equal to 000330 and display 000330 - 000337. 

Eg: 2. E3,351. "CR" would set field 3 equal to 000350 
and display 000350 - 000357. 

All displays give the relative CM address to the left of 
each entry of the display. 

^Q"^^^ PROCESSING On each iteration through the Master Control Loop the Key- 
set Ready flag is examined. If the flag has the value 
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0000 (i.e., not set) the remaining portion of the loo? 
is traversed. If, however, the flag is set, control is 
given to the INTERPRET KEYBOARD MESSAGE routine. This 
routine scans the information in the KB buffer and gives 
control to the proper routine to process the keyed request. 

The requests may be classified into the following groups: 

1. Display mode selection and mode field specifi- 
cation 

2. Central Memory modification 

3. Exchange Jump Package and Control Point modifi- 
cation 

4. Job control 

5 . Debugging Aids • 

The KB interpretive routine first checks for a special for- 
mat (see list of possible requests following this discuss- 
ion) and if request is of this gives control to the routine 
specified (see flow charts A- 17 to A-36) . If it is not 
one of these, the statement is examined for a display entry 
(mode or field ■ change) ; if it is of this type, control goes 
to proper display processor. If the statement still can 
not be identified, it is treated as a possible PP call and 
the RPL and PLD are reached. If a match is made, a re- 
quest is set up in 10/14 and a return is made to PP Resi- 
dent to inform EXEC that there is a request to process. 
If the request is not a PP call, it is considered to be 
an error and the message "FORMAT ERROR" is desplayed on 
the left screen. The Keyset Ready flag is then cleared to 
0000 and control is returned to the Master Control Pro- 
gram. For a complete description of individual request 
processing, consult the DIS flow charts in Appendix A. 
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DIS REQUESTS 



The following commands to DIS refer to the control point 
to which it is attached. Some of the entries cause the 
job to be switched away from the CPU (e.g. when the job's 
exchange package has to be changed) , Execution can be 
resumed using RCP or BKP, Numbers are in octal. 



ENP, 12345. 



. ENA3, ,665000. 



. EMI, 44. 

. ENX5, 2223 4000- 
0000 0000 0200. 
(Spacing unimportant) 

. ENEM, 7. 



. ENFL, 10000. 



. ENTL, 200. 



Set P = 12345. (Next instruc- 
tion address in exchange package). 

Set A3=665000 in exchange 
package. 

Set B2=44 in exchange package. 

Set X5=22234000000000000200 in 
exchange package . 



Set Exit Mode = 7 in exchange 
package. 

Set FL=100000 en exchange pack- 
age. (Storage moved if necess- 
ary). 



Set GPU Time Limit '- 200 sec- 
onds. 



. ENPR, 5. 
. DCP 



RCP. 



BKP, 44300, 



Set job Priority = 5. 

Drop central processor and dis- 
play exchange package (in dis- 
play B) . Using DIS, the exchange 
package is displayed, in any case 
if the job does not have status 
A, B, etc. 

Request central processor. This 
puts the job in W status, and it 
will take the CPU if its priority 
is sufficient. The register set- 
tings of the exchange package 
will be used. 

Breakpoint to address 44300 in 
the program. CPU execution be- 
gins at the current value of P 
and stops when P = 44300. DIS 
effects this by clearing 44300 
to stop the program at that 
point, and restores the origin- 
al word when the stop occurs. 
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RNS. 



RSS. 



ENS . xxxxxxxxxxxxxx . 



■ . GO. 

. 0NSW3. 
. 0FFSW4. 

. HOLD, 



. DROP. 

. DMP (200, 300) 

. DMP (400). 

. DMP. 



Read next control state'.r.cnt 
and obey it. (During use of 
DIS the normal advance of 
control statements is inhib- 
ited) . 

Read next control statement 
and begin execution. This is 
like RNS, except that a cen- 
tral program is only brought 
to central memory, and not 
executed. 

This command allows the entry 
of any control statement as if 
it had been entered on a con- 
trol card. The statement can 
then be processed using RNS or 
RSS. 

This command restarts a pro- 
gram which has paused. 

Set sense switch 3 for the job. 

Switch off sense switch 4 for 
the job. 

This entry causes DIS to re- 
linquish its display console, 
but the job is held at its pres- 
ent status. A console must be 
reassigned to continue use of 
DIS. 

This causes DIS to be dropped 
and normal execution of the job 
is continued. It does not mean 
'Drop the job. ' 

Dump storage from 200 to 277 in 
the output file. 

Dump storage from the job's 
reference address to 377. 

Dump exchange package to out- 
put file. 



(IMP formats are the same as if used on control cards) 



APPENDIX A - DIS FLOW CHARTS 



INDEX 



TITLE 



PAGE 



MAIN CONTROL PROGRAM A- 01 

PRESET INITIAL VALUES A- 03 

MONITOR KEYBOARD A- 04 

INTERPRET KEYSET MESSAGE A-06 

DISPLAY DATE LINE A-08 

DISPLAY ERROR MESSAGE A- 09 

DISPLAY KEYSET MESSAGE A- 10 

DISPLAY CHANNEL STATUS A- 11 

ADJUST DISPLAY PERIOD A- 14 

MONITOR BREAKPOINT ADDRESS A- 16 

ENP A- 17 

ENFL A- 17 

ENTL A- 18 

'ENEM ■ A- 19 

ENTER EM A- 19 

ENA A- 20 

ENB A-22 

ENX ■ A-23 

ENS A- 24 

DROP A-26 

ENPR A- 2 5 

GO A- 27 

RCP A- 27 

DGP A- 28 

BREAKPOINT REQUEST A- 29 

RSS ■ A- 30 
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IXDSX 



ADVANCE A- 30 

RNS A- 31 

HOLD A- 3 2 

ONSW ' A-35 

OFFSW A- 3 6 

■ENTER P, FL, RA, EM A-37 

DISPLAY C, D, E, F, G A-38 

DISPLAY DAYFILE A- 39 

DISPLAY B (EXJ PACKAGE) A-41 

SEARCH FOR SPECIAL FORMAT A- 43 



ODIS 



TEMPORARY STORAGE ALLOCryON 



40/44 BREAKPOINT WORD 

30 REFERENCE ADDRESS 

51 FIELD LENGTH 
52/53 BREAKPOINT ADDRESS 

60 KEYBOARD READY FLAG 

61 KEYBOARD ERROR FLAG 

62 KEYBOARD ADDRESS 

63 EQUIPMENT ADDRESS 

64 DAYFILE DISPLAY COORDINATE 

65 DAYFILE DISPLAY ADDRESS 

66 DISPLAY CYCLE COUNTER 

67 DELAY COUNT 

70 LEFT SCREEN PROGRAM 

71 RIGHT SCREEN PROGRAM 

73 KEYSET INITIAL ADDRESS 

74 CONTROL POINT ADDRESS 

75 INPUT REGISTER- 

76 OUTPUT REGISTER 

77 MESSAGE BUFFER 



PIS - >iAIN CONTROL PROGRAM 



ENTER 



PRESET 

INITIAL \ 

VALUES 



/ 



MONITOR 
KEYBOARD 



/ 



KEYSET READY 



/ 



NO 



SELECT LEFT 
SCREEN, CONSOLE 
CHANNEL II 
ACTIVATE CHAN I* 



DISPLAY 
DATE LINE 



<LEFT SCREEN 
DISPLAY PRO- 
GRAM 



)ISPLAY ERRORS 
MESSAGE 



YES 




B 



INTERPRET 
KEYSET MES. 
AGE 



^ KEYSET MES- ^ 
/ 



■BiacaasJ/ 




A-Ol 



PIS - MAIN CO NTPaL PKOGRAi^I (CO:;TJNLEn) 




DISPLAY 

KEYBOAitD 

PffiSSAGE 



DISCONIffiCT 
iCHAFWEL 11 




SELECT RIGHT 
SCREEN, CHAN 11 i 



ACTIVATE CHAN 11 



/DISPLAY 
CHjim^"EL \\ 

STATUS / 




DISCONIffiCT 
CHANNEL 11 



ADJUST 

DISPLAY 

PERIOD 



/ 



PICK UP BREAK- 
POINT ADDRESS 
P52/53 



IS breakpoint\yes 

p=q option in USE 1^ 



monitor \ 
breakpoint \ 




A-02 



V 
PIS - PRESET INITIAL V.^UZS 



■i'- CP Means Control Point 



ENTER 



!j CLEAR TO 0000 

[ready flag P60 \ 

ERROR FLAG P6l \ 
DELAY COUNTER P67ii 



Tirzr u rmaa m Lti.^ 



SET KB POINTER 
P62 = INITIAL KB 
ADDRESS P73 = 
1300ft 



STORE OUTPUT AD- 
DRESS OF DAYFILE 
BUFFER IN P65 



'SET LEFT SCREEN 
■PROGRAM ADDRESS 
*P70 = DISPLAY DAY 

JFILE _ \ 



.SET RIGHT SCREEN 
PROGRAM ADDRESS 
'?71 = DISPLAY B 



pOI'IPUTE CP* AD- 
■ 'RESS QND STO.RE 

N VI U- CP NUM- I 

ER IN P75 



CLEAR TO 0000 
BREAKPOINT INDI- 
CATOR P52/53 






REQUEST DS 




OBTAIN CHANNEL 
NUJIBER OF DS U- 
NIT. STORE IN 




"X PPU RESIDENT 
\ REQUEST. 
/ . EJ 7-41 



EXIT 



A-03 



l> ' 

PIS - MO NT TO? '-CT^-VTsniRD 



YTE = OOXX, XX is in Display 
Code 



ENTER 



I SELECT RIGHT 
SCREEN, CHAN 11 f 
ACTIVATE CHAN 11 




i — — 

ij SET (A) EQtJlAL 
'(, TO 0055, STOKE |^ 
] IN KB BUFFER 




] INPUT BYTE FROM |] 
KEYBOARD TO A^ 
.DISCONNECT CHAN .j 
11 



/XX = 6lg ? \ YES /is THIS 1ST \ jjO 
I BACKSPACE r~~^! ^^™ INPUT9 J-^; 

\ „ / \ __7 I 



EXIT 




DECREI'iENT KEY- \ 
BOARD ADDRESS P62' 
BY 1 (BACKSPACE) !i 




YES 



SET LAST BYTE 
IN KB^«- BUFFER 
TO 0000 (CLEAR) 



V 




L 



CLEAR KB ERROR ) 
FLAG ■ P 61 



EXIT 



* - KB Means Key Board 



A-04 



PIS - MOi^iTOK i-y>':\r::]s. (rn:; 



LXIT 



e; 



YES 



k:j 



\ CHARACT 



i| BYTi ?62 TO ^'^ 




0000 

11 it-— 



I, 



ri 



^YFlsii 



Tills THE Fi\ 



/^\ 



ij.'.^rv^.-^j.w^ \z 






j-uJl^rtji.^i-* 



taaa^ 



_^^l 

V 



'' stosil the 12 3it; 

BYTE OQjD: IK ; 
II DRESS P6? li 




? ADVANCE KB BUE- li 
jEER POINTER, P62,, 
BY 1 




IS KB BuTFER \ 
FIL,ED ? 
(ma:^ =: 76, 




ij' 3ACKSPCE KB 
f; BUFFER POINTER 
\\ P62 BY 1 



NO 



^i 



^ 



A-05 



DIS - INTER?R?:T keyset I-iES?AGI 



EIJTER 




SEARCH FOR \ 



SPECIAL 
FOBI-LAT 




WAS A VALID 
SPECI/i FOR- 
MAT FOUl-m ? 



\ YES 



NO 



^ 



/ 



,pSET KB BUFFER, 
POl = INITIAL 
ADDRESS P73 



IS THE FIRST \\ j^q // prqcESS 
CHARACTER IN KB l' ^^'^v/ 



BUFFER AN OCTAL/; 



NO 




STORAGE 
ENTRY 



[S 3RD CHAR- 
ACTER A 

" . " ? 
[DIS CODE 57) 




l\ YES 



y PROCESS \ 
^ DISPLAY MODE ^'■•' 



'^IS 3RD CHAR- 
ACTER A 
II II 1 

J DIS CODE 56) 




NO 




PROCESS \ 
DISPLAY FIELD> 
CHANGE 








■^1 



v: 



\7 




A-06 



DIS - INTERPRET KEYSET MESSAGE (C ONTIN UED) 




SET ERROR FLAG 

P61 = ADDRESS OF 
FORMAT ERROR 
MESSAGE 



CLEAR KEYSET READY 
FLAG P61 TO 0000 



CS ERROR FLAG \ 
SET? V 

ie, P61=^0000 



YES 



NO 



<^f 



RESET KB ADDRESS 
P62= INITIAL KB 
ADDRESS P73 



CLEAR ENTIRE KB 
BUFFER TO 0000 




A- 07 



EXIT 



PIS - DISPLAY DATE LINE 



ENTER 



pUTPUT Y COORD- 
pATE 7700 ON 
CHANNEL II 



J 



SET A = 003 0, CM AD- 
DRESS OF DATE LINE 





DISPLAY ONE 
LINE 




A-08 



PIS - DISPLAY ERROR MESSAGE 



(A) CONTAINS ADDRESS OF 
THE FIRST CHARACTER OF 
;^PHOPRIATE ERROR MES- 
SAGE. 



ENTER 



PICK UP ERROR 
FLAG P61 



OUTPUT GHAEACTERIj 
ADVANCE MESSAGE 
i POINTER 



NO 



IS THERE AN 
ERROR ? 



YES 



\"7 



' OUTPUT Y COORD- 
INATE 7100 ON 
CHANNEL 11 



OUTPUT X COORD- ' 
INATE 6000 ON i 
CHANNEL 11 ^ 



PICK UP iNJEXT TWOi 
CHARACTERS FROM 
ERROR r-SSSAGE. 
POINTER, POl 



END OF MESSAGI^ 
( ie. 0000) 



YES 




EXIT 



i- 



A-09 



DIS - DISPLAY KEYSET XEFSAGI 



EI'TTER 



— "^ •— - —■-- ~- ■ — - 



i OUTPUT X COORD- ii 
ilNATE 6000 f! 



P 



^■■.— -.—».>-— —,-^. 






i:OUTPm' Y COOBD- 

:;nate 7066 



_^i 



iFOHiM FAIR OF DIS- 
IPLAI CODE CKilRS 
FROM I^ffiXT TWO KB 
BUFFER BYTES 



iraigWMai ■rawMwaae"-: 



.-^^ 



END OF MESSAGE W ^'^^ ^'^ 



\CI-IARS = 0000 ?/ 



NO 



4, 



OUTPUT TVJO 
CHARACTERS 



ADVAJJCE KB BUF- 
FER ADDRESS 
POINTER, P62, 
BY 2 



NO 



/ 



IS CtlANIvEL 
EMPTY ? 



\ 




YES 



EXIT 



A- 10 



DIS - DISPLAY CHANNEL STATUS 



ENTER 



.^EAD P FROM CENTRAL 
PROCESSOR SAVE IN 



P13/14 



SET DISPLAY CODE FOR 
P (20) INTO HEADING 



f OUTPUT: X COORD 
Y COORD and 
P = 



SET A = P ADDRESS 
SAVED IN P13/14 



■^ 



DISPLAY SIX 
DIGITS 



Q 



OUTPUT: 

. CHANNELS 



INITIALIZE PCX = 00 
FOR CHANNEL ACTIVITY 



IFOBM CHAN ACTIVE 
I JUMP INST. FOR 
JNEXT CHANNEL IN 
POl 




A" 11 



PIS - DISPIAY_aiANNEL_JTATl^S_ (CON^^^ ) 



STATUS 



CODE CHAR 



DISCONNECTED 04 D 
EMPTY 05 E 
FULL 06 F 



■FORM CHANNEL EMP- ij 

TY JUMP INST. FORI 

NEXT CHANNEL IN | 

POl i' 



■SET STATUS D IN 
|a REG TO INITIAL. 
jIZE CHANNEL STAT- 
US SCAN 



U 



/ 



IS CHANNEL 
INACTIVE ? 



A 



NO 



ii 
\7 



YES D-STATUS 



ADVANCE CHANNEL STAT- i| 
US TO E 



/^IS CHANNEL \. YES E-STATUS 




ADVANCE CHANNEL STAT- 
US TO F 



STORE STATUS IN P02 
RIGHT ADJUSTED 



F- STATUS 



ADVANCE CHANNEL NO. 
IN POl 



OUTPUT STATUS CODES YES 






DOES P02 CON- \ 
TAIN TWO STATUS I 
CODES ? 



NO 




^ C 



SCAN NEXT CHANNEL 



DIS - DISPLAY CHANNEL STATUS (CONTIXUEP) 



ej 



OUTPUT TWO STATUS 
CODES IN P02 




HAVE FOUR 

CONSEGTUTIVE 

CODES BEEN 
OUTPUT? 



n NO 




YES 



^ 



/ 



I OUTPUT TWO SPACES 

L 



HAVE ALL CHAN- 
NELS BEEN EX- 
AMINED ? 



NO 





YES 



3Z 




EXIT 



A- 13 



DIS - ADJUST DISPLAY PERIOD 



ENTER 



ADVANCE CYCLE COUNTER i 
BY +1 P66 i 



READ CM''f SECOND CLOCK ! 

FROM CM LOC 00003 1 

i 



.//- 



=>\ 



/f^ukS CLOCK AD- \,, 
llvAi^CED SINCE 
LAST CYCLE? 





UPDATE DIS SECOND CLOCK 



DELAY 6c EXIT 



ADD CYCLE COUNT TO 
DELAY COUNT 




\\ YES i ENTER DIFFERENCE 
'■ «===^V (MAX_378)^IN DELAY 



RESET DELAY COUNTER 
P67 TO INITIAL VALUE 



COUNTER P67 



n^_ 



CLEAR CYCLE COUNTER 
P66 




A- 14 



PIS - ADJUST DISPLAY PERIOD (CC^CI'.rjZD) 




1 



iiREAD CONTROL POINT 
STATUS 



?.SAVE EA IN P50 
SAVE FL IN P51 



NO ERROR AT CONTROL POINT 




EXIT TO 0100 IN PP RESIDENT 



A- 15 



PIS - MONITOR BRAEKPOINT ADDRESS 



STATUS 



CODE 



WAITING 


W 


RECALL 


X 


ACTIVE 


A 


IN STACK 


B to 



* DP Means Breakpoint 



ENTER 



READ P REG FROM CENTRAL 
PROCESSOR 




A' IS THERE AN 

i'/ ACTIVE PPU AT 

\iTHIS CONTROL 

Vpoint? 

YES 



I 



READ CP 

STATUS FLAG 

S^STATUS IN A 
'<vON RETURN 



DOES CONTROL 
POINT HAVE A 
(ACTIVE) S TAT- 



NO 



US ? 



YES 



<7 



SET A = 15, DROP CENT- 
RAL PROCESSOR CODE 





jFORM CM ABSOLUTE 
jBP* ADDRESS FROM 

JBP, P52/33 AND 
iRA, P50 



RESTORE BP WORD 
INTO CENTRAL 
MEMORY 



CLEAR BP ADDRESS 
IN P52/53 




EXIT 



A-16 



PIS - ENP REQ1JEST_PR0CESS0R 
I ENTER [j , 



r 



SET A REG =: 0000 



ENTER P,RA, \ 
FL.EM ^ 




> 



EXIT 



PIS - ENFL REQUEST PROCESSOR 



ENTER 



^''ASSEMBLE^ \^ 
OCTAL DIGITS \ 
>^ RIGHT ADJUSTED^ 



. R 



PICK UP FL, DIVIPE 
BY 100^, STORE IN 
Pll 



SET A REG = 0010 



'PP RESIDENT 



REQUEST STOR 
AGE 





EXIT 



A- 17 



PIS - ENTL REQUEST PROCESSOR 




RETURNED IN P33/34 



SET A REG EQUAL TO 
OCTAL STRING IN P33/ 



ADD 7 TO LOW ORDER 
POSITION AND DIVIDE 






STORE TIME IN 
Pll FOR REQUEST 
PROCESSING 







r 



SET A REG = 0014 
(TIME LIMIT) 



^PP RESIDENT 
'TIME LI MIT 
REQUEST 




PIS - ENSM RE QUE ST PROCESSOR 



uaHBuosa^Bi^SKH 



ENTER 



SET A REG = 0003 



ENTER EM 



y 



> 




EXIT 



PIS .. ENTER EM 
ENTER 



STORE A REG IN P06 



rASSEMBLE 
PIGITS 



I SET A 



> 



A REG = 0016 



PP RESIPENT 
PROP CENTRAL 
PROCESSOR 
IE QUEST 



/ 



COMPUTE APPRESS OF I 
WQRP CONTAINING EM 
IN EXCHANGE JUMP PACK-! 
AGE CP05) 



REAP WORP INTO 

. 20/24 i 



ISOLATE EM COPE <P34) 
STORE IN P20 



WRITE 20/24 INTO EX- 
CHANGE JUMP AREA 




EXIT 



A- 19 



DIS - ENA REQUEST PROCESSOR 



ENTER 



il 



PICK UP NEXT BYTE FROM 
KB BUFFER (POl) 



YES 



il IS IT ALPHABETIC 



NO 



<'; 



IS IT OTHER 
THAN AN OCTAL 



YES 



DIGIT ? 



NO 



0; 



I STORE THE OCTAL IN H 
.1 P 06 • 1! 



li 



ADVANCE KB POINTER 
BY +1 POI 






IS -NEXT BYTE \ NO 

II II 7 \\ 




YES 



Il ADVANCE~KB~BUFFER 
POINTER BY +1 POl 



ASSEMBLE 
DIGITS 



(ERROR) 



\ 



^IS THE NEXT 
BYTE A 'I. 'I ? 



RETURNED 
'IN P33/34 



NO 



=:^ 



If,-, 



SET P6I = 1670 
ADDRESS OF FORMAT 
ERROR MESSAGE 




EXIT, 



YES 



PIS - ENA REQUEST PROCESSOR (CONTINUED) 




J]_ 



I SET A REG = 0016 



PP RESIDENT 
DROP CENTRAL \ 



\ 




COMPUTE CM ADDRESS OF 
An IN EXJ PACKAGE 
OF CONTROL POINT 



READ WORD FROM EXJ 
PACKAGE INTO 20/24 



ENTER NEW A^ INTO 
P22/23 FROM P33/34 



WRITE P20/24 INTO 
EXJ PACKAGE AREA 




EXIT 



A- 21 



E)IS - ENB REQUEST PROCESSOR 



ENTER 






& 




ft « 



NO 



NO 



NO 



PICK UP NEXT BYTE FROM 
KB BUFFER 



/ / ' . " 
S IT AN OCTAL ,^,^ 

NUMBER? 



\ 



YES 



\7 



iSTORE OCTAL DIGIT IN 
iP06 



ADVANCE KB POINTER TO 
NEXT BYTE 



IS NEXT BYTE \x 
I A 11," ? 



YES 



\ 



7 



ADVANCE KB POINTER TOt 
NEXT BYTE 




[S NEXT BYTE 
//A II . 11 ? 



YES 



_V 



SET A = 0016 



V; 



•'^ ~pp~resTden'^ 
drop central 
\ processor re- 

\ QUEST 



i 

llcOMPUTE Xb SOLUTE AD- 1 



U. 



H 



INSERT NEW B^ , WRITE 
BACK TO CM 



V 

EXIT 




SET P6I = 1670, ad: 
DRESS OF FORMAT ERROR 
MESSAGE 



PIS - ENX REQUEST PROCESSOR 




:e ^ 




E' iV 



o< 



ENTER 



1^ 



PICK UP NEXT BYTE FROtj; X NUMBER (0-7) 

KB Buffer 



NO / \ 

IS IT AN OCTAL \ 
NUMBER? 



J 



YES 



<? 



ADVANCE ADDRESS BY 10a 
TO POINT TO X ENTRIES 



ADVANCE KB POINTER TO 
NEXT BYTE 



NO ■ /IS NEXT BYTE 
A 11,1' ? 



\ 



YES 



ADVANCE KB POINTER TO 
NEXT BYTE 



/ASSEMBLE 
^'DIGITS 



/ 



NO 






IS NEXT BYTE 
A ".11 ? • 



YES 



J 



SET A = 0016 




PP RESIDENT 
DROP CENTRAL 
PROCESSOR 



> 



ICOMPUTE ABSOLUTE CM 
ADDRESS OF X ENTRY 



WRITE NEW 60 BIT WORD 
INTO XJ PACKAGE 







EXIT 




5f 



SET P61 = 1670 
ADDRESS OF FORMAT 
ERROR MESSAGE 



A- 23 



PIS - ENS REQUEST_1R0CESS0R 



ENTER 




IS IT A SPACE \ YES 



(55, DIS CODE)] 






V7 




FORM 


ADDRESS 


OF CONTROL 


] POINT 


CONTROL 


. STATE- t 


MENT 
,P05 & 


BUFFER, 
P02 


SAVE IN 



! CLEAR THE NEXT WORD OF 

CONTROL STATEMENT BUF- 
FER 




NO /HAS ALL OF THE 
BUFFER BEEN 
CLEARED? 




YES 



<f 



JREAD WORD 021 OF CP 
INTO 10/14 



SET ADDR OF NEXT CTL 

STATEMENT TO THE 1ST 
WORD OF THE BUFFER 



WRITE 10/14 BACK INTO 
CONTROL' POINT AREA 



l.<? 



CLEAR PIG/ 14 




A_0/, 



DIS - ENS REQUEST PRO CESSOR (GONTINUED) 



o 



SET P02:=10, ADDRESS OF 






PICK UP NEXT BYTE FROM 
KB BUFFER, STORE IN 

UPPER 6 BITS OF AS- 
SEMBLY AREA (P02) 




PICK UP NEXT BYTE 
FROM KB^;BUFFER, . " j 
STORE IN LOWER 6 BITS 
OF ASSEMBLY AREA (P02)j 




YES 



VANCE KB BUFFER POINT 



ADVANCE ASSEMBLY AREA 
iPOINTER BY +1 P02 



NO 



END OF ASSEMBL"!i 
AREA ? 



END OF STATEMENT 



WRITE PIG/ 14 INTO LST 
OF THE' CONTROL 
STATEMENT BUFFER 



J/. 




EXIT 




.D K- 



YES 



V? 



WRITE P10/I4 INTO CP 
STATEMENT BUFFER 
(P05) 



ADVANCE STATEMENT 
BUFFER ADDRESS P06 



A" 25 



PIS - DROP REQL'EST PROCESSOR 



ENTER 




EXIT 



TO DROP DIS IN ADJUST DISPLAY PERIOD 



PIS - ENPR REQUEST PROCESSOR 



ENTER 



jCassemble . 

OCTAL DIGITS v> 

RIGHT AD- / 
JUSTED / 



STORE PRIORITY IN 
Pll 



EXIT 




A- 26 



DIS - GO REQUEST/PROCESSOR 




] COMPUTE CM ADDRESS- OF 
■j CONTROL POINT DAYFILE 
JMESSAGS BUFFER (1ST 
iWORD) 



CLEAR DAYFILE MESSAGE 



COMPUTE RA and READ 
CONTENTS OF RA INTO 
PlO/14 



CLEAR BIT' 00 OF P13 
AND WRITE PIG/ 14 
BACK INTO RA IN CH 




EXIT. 
DIS - RCP REQUEST PROCESSOR 





ENTER - 










1 SET. A REG = 0015^ ... 









pp resid ent\ 

REQUEST CEN- \ 
RAL PROCESSOP'^^ 




A- 27 



DIS - DCP REQUEST PROCESSOR 



ENTER 



SET A REG = 0016 




PP RESIDENl\ 
DROP CENTRAL \ 
PROCESSOR 
REQUEST 



PICK UP BREAKPOINT 
ADDRESS IN P52/53 



IS IT EQUAL 
TO 0000 ? 




COMPUTE ABSOLUTE CM 
ADDRESS' OF BP FROM 
RA P50 AND P52/53 



YES (NOT BEING USED) 



WRITE INTO CM THE WORD 
SAVED IN P40/44 FROM 
BP INITIALIZATION 



CLEAR BP ADDRESS 
P52/53 




EXIT 



A-28 



PIS - INITIATE BREAKPOINT REQUEST PROGSSSC 



OA 



ENTER 



ASSEMBLE \ RETURNED IN P33/34 
DIGITS ^ 




PICK UP BP ADDRESS 
DIVIDE BY lOOa 



DOES BP AD- 
' DRESS LIE WITHIN Yi 
.FIELD LENGTH? f 



NO 



YES 



SI 



STORE BP ADDRESS IN 
P52/53 



COMPUTE ABSOLUTE '.CM 
ADDRESS OF BP FROM 
RA AND BP ADDRESS IN 
P53/52 



READ CM WORD AT THIS 
LOCATION INTO P40/44 



CLEAR BP WORD IN CM 



SET A REG = 0015 



PP RESIDEN 



REQUEST 
CENTRAL 
PROCESSOR 




3-f 

"Vi; 



SET A REG -=5160 
I ADDRESS OF OUT OF 
RANGE MESSAGE 



^J 



"'l^ EXIT 
A- 29 



PIS - RSS REQUEST PROCESSOR 




PLACE DISPLAY CODE FOR 



ADVANCE TO \ 

NEXT CONTROL \ 

^STATEMENT / 




EXIT 
PIS - ADVANCE TO NEXT CONTROT. STATRMRMT 



ENTER 



READ CP WORD 021 INTO 
PlO/14 



PICK UP ADDRESS OF NEXTJ 
CONTROL STATEMENT FROM 
P14, READ INTO 10/14 



PICK UP FIRST BYTE OF 
STATEMENT 



JL 



IS IT EQUAL TO 
0000 ? 



SET A REG = 0020 



YES 




EXIT 



A-30 



PIS - RNS REQUEST PROCESSOR 




STORE DIS CODE FOR 
"lA" IN PIO 



PICK UP CONTROL POINT j 

ADDRESS AND CONVERT j 

TO CONTROL POINT NUMBER, 



r 



II 



■PLACE DIS CODE FOR 
"Jn" IN PIl 



WRITE PIG/ 14 INTO 
PP MESSAGE BUFFER 
(IN P77) 




EXIT 



A- 31 



PIS - HOLD REQUEST PROCESSOR 



ENTER 



PICK UP EQUIP ADDRESS 
FROM tea, SA.VE IN PIl 



SET A REG = 0023 



PP RESIDENT 
DROP EQUIP 
y REQUEST 



\ 



\ 



j SET A REG = CHANNEL 
NUMBER OF DIS 



li 



J^ PP resident\ 

^ROP channel \ 

request / 



e/ 



set P02 = 0002 



SET A REG = ADDRESS OF 
LAST DAYFILE MESSAGE 



WRITE INTO ADDRESS IN 
A REG: 
"REQUEST DISPLAY." 






SET A REG = 0017 




A-32 



PIS - HOLD REQUEST PROCESSOR C 



o 




YES 




PP RESIDENT ,\. 

PAUSE FOR RE-\ 

LOCATION RE-r / 

QUEST • • '■ / 

I 



READ CP STATUS (020). 
INTO 10/14 



'^ IS ERROR, FLAG X\- -NO 



(PI4) = 0000? \ 



V? 



READ CP STATUS WORD 
(022) INTO 10/14 



LOOP FOR DIS ASSIGNMENT 
BY OPERATOR 




IS OPERATOR 
ASSIGNED FLAG 
= 0000 
(P14) 



NO 



STORE EQUIPMENT NUMBErI 
IN P63 



ERROR CONDITION SET 



SET A REG = 0012 



y ^p resident \ 

/RELEASE PPU \ 
\ REQUEST / 




EXIT TO 0100 

OF PP RESIDENT 



CLEAR P14, WRITE STATUS 
WORD (022) INTO CP 
AREA 



frCT)HP"irrE~ATD'DW£rj 

OF LAST DAYFILE MESSAGEJ'^ 
IN CP AREA 



CLEAR LAST DAYFILE 
MESSAGE 




A-33 



PIS - HOLD REQUEST PROCESSOR JCONTINUED) 




READ EST POINTER FROM 
CM 000005 INTO 10/14 



COMPUTE ABSOLUTE AD- 
DRESS OF EQUIP IN P63 




i SET A REG = CHANNEL 
NUMBER (P20) 




MODIFY 
PARAMETERS 




EXIT 



A-34 



PIS - OMSW REQUEST PROCES S OR 



ENTER 



/ASSEMBLE 
'DIGITS 



RETURNED IN P34 



ISOLATE LOWER THREE 
BITS OF P34, IN A 



FORM COMPUTED J LEFT 
SHIFT, BIASED BY 5 



SET A REG = 0001 



PERFORM COMPUTED SHIFT 
(TO PROPER SW POSITION) 



STORE MASK IN POL 



COMPLEMENT A AND SAVE 
AS m OPERAND OF LPC 
INSTRUCTION. 



READ WORD 026 OF CP 
AREA INTO PlO/14. 
(PICK UP SENSE LIGHTS 
AND SWITCHES) 



"OR" ON BIT FOR THE 
SWITCH IN REQUEST. 

P14 



WRITE UPDATED CM WORD ! 
IN PlO/14 INTO 
CONTROL POINT AREA 



^1 



PICK UP WORD AT RA, 
UPDATE SWITCH SETTING 
AND WRITE BACK INTO 




EXIT 



A- 35 



p is - OFFSW RE QUEST PROCESSOR 



ENTER 



''ASSEMBLE \ ' 



DIGITS 




I ISOLATE LOW ORDER 
i THREE BITS OF P34 



!l 



i FORM COMPUTED LEFT 
SHIFT, BIASED BY 5 



RETURNED IN P34 



SET A REG = . OOQl 




COMPLEMENT A AND STORE [ 
AS A MASK 




COMPUTE ABSOLUTE AD- 
DRESS OF WORD 026 OF 
CP. READ INTO PI 0/14 



PICK UP P14, "AND" 
WITH PRESET MASK 



WRITE PIG/ 14 INTO 
CONTROL POINT AREA 



PICK UP CONTENTS OF 
RA. "AND" WITH PRE- 
SET MASK. 



l;^^RITE BACK INTO 
RA. (IE: RESTORE 
UPDATED SENSE LIGHTS 
AND SWITCHES) 




EXIT 



A-36 



PIS - ENTER P, FL. RA. EM 



ENTER 



! STORE A REG IN P06 i- 

'(INDEX IN THE CP EX- [i 

CHANGE JUMP PACKAGE) '■ 



/^ASSEMBLE \ 
\. DIGITS } 



.SET A REG = 0016 



RETURNED IN P33/34 



/ pp resident\ 

•'^ DROP CENTRL \ 

processor 

REQUEST 



COMPUTE ADDRESS OF 
EXJ PACKAGE + P06 



READ THE WORD INTO 
20/24 



INSERT NEW VALUE • IN 
j 33/34 INTO P20/21 



WRITE WORD IN 20/24 

BACK INTO EXJ PACKAGE 
AREA 




EXIT 



A- 37 



PIS - DISPLAY C , D, E, ?, 



ENTER 



SET P24 = ADDRESS OF \ 

1ST ENTRY OF DISPLAY j 

FIELD TABLE. (EACH • ' I 

TYPE OF DISPLAY HAS ITS I 

OWN TABLE) i 

MODE ADDRESS ] 

C 1470 I 

D 1520 I 

E 1550 j 

F 1600 j 

G 163 j 

NOTE: EACH TABLE HAS 

FOUR ENTRIES, TWO PPU ! 

WORDS EACH. CORRESPOND-' 
ING TO FIELD. I 



SET A REG = ADDRESS OF 
DISPLAY FORMAT PROCES- 
SOR: 



MODE 
C 
D 
E 
F 
G 
■NOTE: ■ 
(3 000)=4GRPS 
(2600)=5GPS 



ADDRESS 
3000 
3 000 
3000 
2600 
2600 

OF 5DIGTS 

OF 4DIGTS I 
i 

r 




EXIT 



A- 38 



DIS - DISPLAY DAYFILE 



ENTER 




i SET P04 = INITIAL DFB* [ INTO P20/24. 
' DISPLAY ADDRESS 
STORED IN P65 



SET P03 = INITIAL Y 
COORDINATE VALUE 
STORED IN P64 



YES 



DOES P04 
DFB INPUT 
P21 



DFB STATUS WORD HAS- BEEN READ 



DFB 
20 


INP 
21 


OUT 
22 


LIM 
23 


24 




A Jr 



NO 



\f 



YES /has Y COORD- 

[ [ INATE BEEN RE- 

\ DUCED TO 200, 

\bottom of DISP 



li DECREMENT Y COORDINATE 
IN P03 BY 128 



NO I 



OUTPUT Y COORDINATE 
IN P03 



/DOES P04 = \ ■ YES 
JJDFB LIMIT (P23) \ 



NO ^1^ 



J 




SET P04 = P20. IE: 

*.,; RESET POINTER TO 1ST 
Ij WORD OF DFB. 



PIS - DISPLAY DAYrlLE (COXTIXUSD) 




SET P64 = 7646 
(RESET Y COORDINATE) 




READ DFB FROM ADDRESS 
IN •P65 : INTO P10/I4 1 



ADVANCE DFB POINTER 
BY +1 P65 





NO 



/DOES DFB POINTi^ „„„ 
ER EQUAL LIMIT |. 



NO 



i = 



IS THE LAST 
BYTE OF DFB 
0000? 



RESET P65 = DFB 1ST 
WORD ADDRESS 



YES 



^. 



<(' 



DOES P64= 
7660 (UPPER 
DISPLAY Y COORD)! 





EXIT 



A-40 



DIS - DISPLAY B 



ENTER 



SET P07 = Y COORDINATE 
7650 



< 



DISPLAY 
^CONTROL POINT 
STATUS 



\ 



j DECREMENT Y COORDINATE 
IN P07. OUTPUT P07. 




COMPUTE ADDRESS OF LAST| 
DAYFILE MESSAGE IN 
CONTROL .POINT AREA 



DISPLAY LAST 
vDAYFILE MES- A 
SAGE . / 



DISPLAY 
NEXT CONTROL 
STATEMENT 



PICK UP RA FROM EXJ 
AREA 



o 



A- 4 1 



PIS - DISPLAY B (COXTiyjED ) 



■aaoMMOHB^A 




IS THIS THE 
fSAME EA AS STORED^: NO 
IN P50? 



/ 




EXIT 



YES 



I STORE CONTROL POINT 
{address in P06 



DISPLAY 
EXJ AREA 




EXIT 



A-42 



PIS - SEARCH FOR SPECIAL FGRI-IAT 



ENTER 







i 



I SET P07 = ADDRESS OF THE 
THE FIRST ENTRY OF THE 
PATTERN TABLE 



!l 



STORE INITIAL KB ADDRESS 
IN LOG POL 



STORE ADDRESS OF PAT- 
TERN TABLE IN P02 



NO MATCH 



EXIT 




ADVANCE RETURN 
ADDRESS SET BY 
RJ, BY+1 



YES /h 



mS THE ENTIRE 

pattern table 
::;been searched? 

■(P02=0000) 



NO 



r 



PICK UP WORD INDIRECT- 
LY FROM P02. (WORD 
has the FORM: OOXX) 



ADVANCE P02 AND POl BY 
+1. GET SET TO COMPARE 
NEXT CHARACTER IN STRING 




\7 



HAVE THE CHARS 
IN PATTERN TABLE I 
BEEN SCANNED? 



NO 



^■7 



JOES WORD AT 
(POl) = WORD 
READ FROM PAT- 
TERN TABLE? 



YESi 



o 



LAST WORD = 0000 



YES 



NO 



Vsp 



GO PROCESS 
S PECIAL FORM AT 
RJ 02, P02 



7 



ADVANCE PATTERN 
TABLE POINTER BY 
+1 P07 



f^. 



^ 



,X^ 



EXIT 
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DISK ROUTINES AND OVERLAYS 



Introduction 

In the Chippewa Operating System, there is no single system element used 
to perform disk operations for all other elements of the system. 
Instead, each system element performs its own disk operations. This, 
while requiring additional coding for each of the system elements using 
the disk, eliminates the need for a request queueing and priority 
scheme required by the use of a single system element to process all 
disk operations. In addition, the housekeeping required by a disk 
subroutine in one system element can overlap, to some extent, a disk 
operation being performed by another system element „ Among the system 
elements which perform disk operations are: 

• peripheral processor resident (reads transient programs from the 

disk library) 

MTR (writes the contents of the dayfile buffer to the disk) 
o some transient programs (read overlays from the disk) 

Disk operations for external users are performed via the overlays 
2WD (write disk), 2RD (read disk), and 2BD (backspace disk). These 
overlays are called by CIO when a disk operation is requested by a 
central processor program. In addition, these overlays are used by 
certain transient programs to perform disk operations. Thus, ILJ 
and ILT call 2Wir when loading jobs from the card reader and a tape unit, 
respectively, while IDJ and ITD call 2KD when transferring job output to 
the printer or a tape unit. 

Regardless of where in the system they are performed, disk operations are 
similar: this discussion will therefore be limited to the overlays 
2WD, 2RD, and 2BD. Before discussing these routines a short review of 
the physical characteristics of the 6503 disk file is in order. 



6603 Disk File: Description and Organization 

The 6603 Disk File contains fourteen disks, each coated on both sides 
with magnetic oxide. Thus, there are a total of twenty-eight recording 
surfaces. On two of these surfaces timing tracks are recorded, two are 
used for spares, and twenty-four are used for recording data (see figure 1), 
All fourteen disks are mounted (in a vertical plane) on a common axis and 
rotate at a speed of approximately 900 revolutions per minute. Twelve 
of the data surfaces are on the right side of the unit, and twelve are 
on the left. Information is recorded on the disk in 12-bit bytes: 
each bit in a 12-bit byte is recorded on a separate disk surface. 

Associated with each disk surface is a set of four read/write heads 
(see figure 2). An assembly consisting of a rocker arm and a head bar 
fits between each pair of facing disk surfaces. The head bar holds two 
sets of four heads, one set for each of the two facing surfaces. The 
read/write heads are' mounted on this head bar in a fixed position 
relative to each other. The rocker arm- head bar assemblies for all 
disks mount on a common bracket which can be rotated. This rotation 
moves all the head bars simultaneously (with the exception of the 
heads accessing the timing track surfaces: these heads are fixed). 

The disk surface is divided into four zones. A zone is that portion of 
the disk surface transversed by one of the four heads associated with 
that surface as the head (on its head bar-rocker arm assembly) moves 
through its maximum angular rotation. A byte may be written on the 
twelve data surfaces on the right side of the disk file or on the 
twelve data surfaces on the left side of the disk file: on either side, 
a byte may be written in any one of four zones. On each side of the disk 
file and for each zone on side, a single set of twelve read/write heads 
are used to record a byte (see figure 1). This set of twelve heads is 
called a head group . There are four head groups for each of the two sets 
of twelve disk surfaces: a total of eight head groups. 

Each zone contains 128 tracks . A track is the recording path available 
to a given head group in a given position as the disk makes a complete 
revolution. To move from one track to another requires a physical 
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movement, or repositioning , of the head bar-rocker arm assemblies. At 
a given position, each head group accesses the same track in its zone. 
Thus, if head group 2 is positioned to track 125, the other 7 head 
groups are also positioned to track 125. 

Tracks arc divided into sectors : a sector is the smallest addressable 
segment of a track. There are 128 sectors in each of the tracks in the 
tv/o outer zones. In the two innermost zones, there are only 100 sectors 
per track because of the reduced track length near the center of the 
disk compared to the track length available near the outside edge. A ' 
sector contains 351 bytes (each bit in a byte is recorded in one of 12 
corresponding sectors across 12 disk surfaces). The first four bytes 
recorded are reserved for use by the controller: They provide a time 
lag between consecutive sectors and contain all zero bits. After the 
last data byte has been written, the controller writes a longitudinal 
parity byte, . The sector format is illustrated in figure 3. Of the 
351 bytes in a sector, then, five are used by the controller: The 
remaining 346 bytes may be used for data. Normally, 320 bytes (the 
equivalent of 64 central memory words) are used for data. 

The number of words read from or written to the disk is solely a function 
of the word count specified in the lAM or GAM instruction. It is 
possible to read or write more than one sector at a time; it is 
possible to read or write in the group switch gap; it is possible for 
a read or write to wrap around on the same track. A read or write 
operation always begins at the beginning of a sector. When a write is 
initiated, the disk controller inserts four zero bytes before the data 
and inserts a parity byte after the last data byte. (The parity byte 
is not necessarily in the last byte position in a sector.) When a read 
is initiated, the controller assumes that the first four bytes are zero 
bytes, and does not pass these on to the data channel. When the word 
count in a read has been reduced to zero, the controller assumes that the 
next byte to be read is the parity byte. Thus, any attempt to read a 
number of bytes different than the number of bytes written will invariably 
create problems due to the interpretation of zero bytes and parity bytes 
as data and vice_, versa. For this reason, regardless of the amount of 
data to be recorded, a fixed number of bytes is written in each sector. 




Figure 2 



■ 5- 




^1 

k 
-^ i 

81 

s 

£ 

o 



Figure 3 



-6- 



and only one sector is written at a time (i.e., data is recorded in 
physical records of one sector). 

A reference mark on the disks containing the timing tracks defines the 
beginning of sector in all four zones. Beyond this point, the 
scarting point of sectors in the two inner zones does not coincide with 
the starting point of sectors in the two outer zones (see figure 2). 
The clock surfaces contain timing tracks for each zone. As the disk 
rotates, one of these timing tracks (depending on which head group is 
selected) drives a cell counter. This counter in turn triggers a sector 
counter. Both counters are initialized when the reference mark is 
detected. The cell counter is incremented as the timing track is read: 
When it reaches a count of 351, it is reset and the sector count 
advanced. The controller compares the sector number specified in a read 
or write function code: When equality is obtained, the read or write 
operation is initiated. The contents of the sector counter appear in 
the low-order 7 bits of the status response. 

6603 Disk File; Timing Considerations 

The rotational speed of the disk is approximately 900 revolutions per 
minute, corresponding to a revolution time of about 66 milliseconds. 
The time required to read or write a byte is approximately 1.4 micro- 
seconds on the two outer zones and 1.8 microseconds on the two inner 
zones. In the outer zones, then, a sector passes under the heads 
every 490 microseconds. It requires a minimum of 325 microseconds to 
transfer the 64 central memory words in a sector from peripheral pro- 
cessor memory to central memory, and, because of memory and pyramid 
conflicts, will probably require longer. A single peripheral processor 
cannot maintain a continuous data flow between consecutive sectors on the 
disk and central memory. 

If the programmer wishes to read or write in a given sector, he simply 
issues the appropriate function code and, when the sector comes under 
the heads, the operation is initiated. The programmer may prefer to 
minimize the time spent waiting for this sector by sensing (via a 
status request) the position of the disk. Timing considerations make 
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it impossible to sense for a given sector and then initiate an operation 
in that sector: If one wishes to read or write sector N, then sector 
N-2 should be sensed in order to assure that a revolution will not be 
lost. 

There are two types of delays v^hich are of concern to the disk programmer. 
One of these is the positioning delay ; The time required to move the 
heads to a new track. When a track select function has been received 
by the disk controller and positioning initiated, a delay determined by 
counting -two- reference marks is provided to permit the head assembly to 
stabilize. Thus, depending on when positioning is initiated, up to 1-33- ^Cr C\. 
milliseconds may be required. During positioning, a status request will 
receive a "NOT READY" reply. 

The second type of delay is the switching delay encountered when a 
different head group is selected. When head group switching is initiated, 
the controller provides a one millisecond delay to allow the circuits to 
stabilize: Furthermore, reading or writing cannot be initiated until a 
reference mark is detected. Thus, depending on when the head group 
select function is issued, up to 66 milliseconds may be required for head 
group selection. 

Between the last sector in a track (sector 127 in the outer zones, sector 
99 in the inner zones) and the first sector (sector 0) on that track 
is an area called the group switch gap (see figure 2). This area is 
approximately equivalent to three sectors in size. It is provided to 
accommodate the minimum 1 'millisecond switching delay. A programmer can 
thus read or write the last sector in a track, select a new head group, 
and read or write sector zero of the new track without incurring a 
delay. 

The function code for head group selection is 160X, where X is the head 
group number (0-7). It is possible to vary the second octal digit in this 
function code (normally zero) from 1 to 7: In doing so, the manner in 
which the data signals from the disk are sampled is varied. Use of the 
feature is reserved for error routines. 



6G03 Disk File; Data Capacity 

There are 128 physical positions of the heads: At any one position, 
a track may be accessed by selecting one of eight head groups. Thus, 
the disk has a total of 8 x 128 = 1024 tracl^. Of the eight head 
groups, four cover inner zones and four cover outer zones. In the 
inner zones, there are 100 sectors per track: In the outer zones, there 
arc 128 sectors per track. Therefore, 512 tracks each contain 100 sectors 
while the other 512 trades each contain 128 sectors. The disk file thus 
contains 116, 736 sectors. In normal use, up to 64 central memory words 
are recorded in a sector. The capacity of the 6603 disk file is thus 
approximately 7.5 million central memory words. 



Chippewa Operating System Disk Usage 



As we have seen, a single peripheral processor cannot maintain a con- 
tinuous data flow from consecutive disk sectors to central memory. 
Therefore, the Chippewa Operating System uses a half track scheme in 
its disk operations. A half track is composed of either the odd-numbered 
or the even-numbered sectors in a track. In a disk operation, the system 
reads or writes alternate sectors, transferring data to or from central 
memory while passing over the intervening sector. Since the disk 
contains 1024 physical tracks, the equivalent half track capacity is 
2048. The allocation of half tracks is controlled by MTR: disk 
write routines obtain half track addresses from MTR via the Request 
Track function. MTR maintains a table called the Track Reservation 
Table (TRT) which contains an entry for each half track on a disk. On 
receipt of the Request Track function, MTR searches the table for an 
unassigned half track, and returns the half track address to the requestor 
in the upper byte of the Message Buffer. If no half track is available, 
a zero address is returned to the requestor. A half track is never 
split between files: thus, the half track is the smallest unit of 
storage allocated on the disk. 

The format of the half track address, and its relationship to physical 
disk addresses, is illustrated below. 
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1XXX}[X}0CXXXX 



head group nuraber (0-7 „) 

o 

"1" if odd sectors, "0" if even sectors 

track nuauber (0-177 „) 

o 

Sector numbers maintained by the system (such as the Current Sector 
in an FST entry) are logical, sector numbers, and refer to a sector 
within a half track. In the outer zones, sectors within a half track 
arc numbered 0-77g: In the inner zones, sectors within a half, track are 
numbered 0-61^. To convert a logical sector number to a physical sector 

number, the system shifts the logical sector number left one place and 

4 
inserts the 2 bit from the half track address into the lOT,7-order bit 

position. For example, consider logical sector 77. (53^^) in a half 

o 10 - ■ 
track composed of the odd-numbered sectors in a physical track. In this 

case, the 2 bit of the half track address will be a "1". By shifting 
the logical sector left one place and inserting the "1" bit from the 2'^ 
bit position of the half track address, we obtain 177„ (127 ) for the 
physical sector number. For . the remainder of our discussion, a reference 
to "sector number" will refer to the logical sector number unless other- 
wise described. 



For files recorded on the disk, the physical record is, of course, the 

sector. A logical record may be composed of several sectors. The 

format of the physical record is shown in figure 5. 502 bytes are 

always written in each sector. The first two bytes written are control 

bytes: the remaining 500g bytes are data bytes. Control byte 2 contains 

the number of useful central memory words in this sector: If control byte 

2 contains lOOg, all 500g bytes in this sector contain useful information. 

A sector in which control byte 2 contains less than 100 is called a 

8 
short sector, and is interpreted as a record mark. A logical record 

may comprise several full sectors, but is always terminated by a short 

sector. If the data to be recorded as^ a logical record is a multiple of 

lOOg CM words, the system will write, as the record marlc, a sector in 

which control byte 1 contains zero. 

Control byte one points to the next physical record in this file. If 
the next sector is on the same half track, then this byte contains the 
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nuraber of that sector. If the next sector is on another half track, 
then this byte contains the half track address for that half track. 
(The file would be continued beginning with sector zero of the new half 
track.) 

At the end of each write operation, the system writes a file mark. The 
Current Sector byte of the FST entry is not incremented to reflect this 
■ file mark sector, so the effect is equivalent to writing a file mark 
and backspacing over it. On the disk, a file mark is a sector in which 
both control bytes contain zero. 

. The Disk V7rite Overlay, 2WD 

Disk write requests by users are executed by CIO's overlay 2WD. This 
overlay is also used by lU and ILT in loading jobs on the disk. Before 
calling 2WD, CIO calls the 2BP overlay to check the legality of the buffer 
parameters FIRST, IN, OUT, and LIMIT. After checking these parameters, 
2BP searches the File Name Table for the file name specified in the CIO 
call (i.e., in the first word of the argument list). When found, 2BP 
stores the address of the corresponding FST entry. Should the file name 
not be found in the FNT, 2BP constructs an FNT entry for this file. 
Finally, 2BP clears the 2 bit in the buffer status byte of the FST 
entry to reserve the file. 

CIO then calls 2WD. (Refer to the flow chart on page A-1.) 2WD reads 
the FST entry for the file and extracts the equipment number from byte 
one. The equipment number is added to the EST base address, and the 
EST entry read. The channel number from byte 2 of the EST entry is then 
inserted in the appropriate I/O instructions. 

The output data in the circular buffer may appear as a contiguous block, 
or may wrap around the buffer, as illustrated in figure 6. In computing 
the total number of sectors in the circular buffer, then, the 2WD routine 
first subtracts OUT from IN. If the difference is positive, then this 
difference is the total number of words to be written, and 2WD shifts 
off the lower six bits of this word count in order to obtain the 
equivalent number of sectors. If OUT-IN is negative, the value of 
LIMIT is added to the difference and FIRST subtracted to obtain the 

-13- 





















c/: 














LC 








CO 




iJ 












Ci 


















<-^ 


>• 






CO 


• • 


r^ 


^ 


^ 




CO 


o 




a 












c'i 


fri 




^ 








M 




o 


rt 


C5 




H 


H 


o 


H 


:d 




§ 


o 




fe 








Pi 




J — i 


o 




o 


<t 


c 




§ 




H 




—V 




H-i 


Z 






o 




1—4 


CO 


:=! 








o 




C/j 








c^ 


oi 




C-' 


U 


c"" 


o 




« 


:d 


=i 


P-i 






o 




Q 


« 


z 


Cd 




fn 




uz 


k; 


<; 


aJ 


PS 


o 


00 


o 


1-1 


w 


M 


5: 


W 




o 


M 


O 


IS 




t^ 


'r-' 


Pi 




M 








H 


Uj 


u 




la 


< 


5: 


w 


^ 


^ 


C/0 


J2II 




a 


O 


o 


"^1 




i^ 






o 


P 


j---; 




H 




CO 


M 


o 


r^ 


£ 






u 




M 




i— ' 


H 


CJ 






^ 


f-" 


Uj 




a 


'^-' 


»^ 


^ 


H 






z 


a 


^ 


^ 


^•u 


H 


»-J 


-^ 


pu 


►J 


t- 


^ 




<- 


1-^ 


c 


•—•■ 


Cii 


s 




o 


E 




H 


CO 


W 




o 


Clj 




-J 




t^ 


3 


< 


*—( 


o 




o 




^ 


J 


1z^ 


P:i 


Z 


<; 


H 








a 










M 


CO 




la 


!-> 


S3 


pM 


f-' 


p-4 




/-^ 




a 


i-i 


p-( 


c 


O 




I^ 


a 




— 


^-*» 


o 


-r* 


HH 


--t 












p 




H 


O 




« 


5 


E^ 


z 


.J 




^> 


J3 


r-*; 




P3 




[•-•; 


LO 




O 


a 


J 




b 


a 




•— ' 


^ 


^ 


n> 


H 


vO 


UJ 


<; 


W 


< 


1 


VO 


o 




^ 


H 






-.-^ 


V.X 


-v 


Pi 








:d 


X 


r.1-. 




H 




O 


O 


C_j 


y~t 


H 


£5 


r^ 


~-i 


H 


I 




T-* 


''^ 


O 




§ 


Z 


S 


a 




o 


ci 
o 


Pi 


H 


w 


O 


O 


O 


Ti 


li^ 


^ 


3 


n 






o 


^ 


(5 


^ 


CO 


H 


H 




z 


i-l 


'r^ 


a 




o 


H 


CO 


O 


5 
Pi 


H 




H 


tr-l 


i-( 


O 


z 


O 


z 


6 




O 


t-^ 


M 


'_g 




O 


wH 






3 


g 


O 




CJ 


2 






Z 






H 


M 










O 


M 


J 


jj] 


> 


Z 


a 


1 


^ 


Q 




z 


o 


w 


1— t 


h-l 


W 


M 


DJ 


t/; 


Ci- 


rt 


M 


z 


fcj 


z 


z 


Pi 


^ 


1 


M 


1— 1 


CO 




b 


bj 




Pi 


M 


H 


CO 




CO 


*^ 


H 




t-H 


Pi 


H 




H 


w 


H 


a 


M 




o 


H 


o 






M 


<; 


H 


H 










Dh 


CO pi 


1^ 


Iij 


W 


=i 


o 


^ 


H 


^3 


w 


S 


u 


H 


H 


^ 

H 


:=! 




CO 


H 


J 


c2 


rs 


ba 


fcj 


z 


Pi 


H 


Hd 


w o 


Cii 


0-| 


§ 




s 


CO 


Z 

3 


&4 


g 


C- 
^ 


g 




Z 

3 


o 


CO 

M 


g 




Q 


H 


a. 


o 


« 


o 


M 


M 


H 


o o 


ru 


o 


o 


o 


w 


>H 


o 


O 


w 


o 


w 


I^ 


O 


X 


fn 


T^ 


o 


Oj 


Z 


D 


o 


o 


o 


fej 


CM 


W 


Pi u 




o 


& 


o 


M 


m 


o 


O 


« 


o 


m 


1/1 


o 


W 


o 


H 


s 


CO 


< 


CO 


CJ 


H 


H 


n 


o 


CO 


CO 


P-i CO 




• 




• 








■ • 




, 








■ 












, 



















m 



vO 



><!! 









Q 




pil 




Z 


Z 




a 




a 


a 




>; 




H 






o; 




H 


Pi 








M 


o 




o! 




Pi 










S 


o 
o 




1 




Pi 


a 




O i| 




o 


Pi 




z 




H 




H 


M"! 




CJ 


Q 


CO 


c~ 




a 


z- 


a 


CO 

a 




CO 


a 


JD 








c 




J 


a 


S 


o| 




<d 


M 


Pi 




M 






P-i !! 




H 


>* 


a 


f 


•v 


Pi 


S 


J 


pi' 


> 


V <; 


z 


H 


a; 




^^ 


o 


fa 












Pi 








a !; 


a 








a ! 


a 








a; 


S 








1 — ' ' 


m 








^i 










Pi 








<■'• 


3 


Pw 








t3 


fq 






u 


CM 






Pi 








Gi 


H 


>^ 






O 


m 










Q 










s 










o 










H 










CO 










s 










M 




















^ ■ 








N. 


M 








\ 


o 










V ^ 









-14- 



Figure 6 



total v;ord count and, from that, the equivalent nurdber of sectors. 

R.cgardlcss of whether the data is contiguous or wraps around the buffer, 
2WD proceeds on the assumption that the data does v/rap around,' and 
proceeds to compute the values needed to process the wraparound case. 
The steps involved are listed in figure 6. These values, although 
always computed, are not required in the contiguous case: in either 
case, the terminal path is entered when the total sector count is reduced 
to zero. By computing these values regardless of whether the data is 
contiguous in the buffer or wraps around the buffer, computations during 
the period when the disk is actively in use are reduced. 

Next, 2WD picks up the channel number from the EST entry and requests 
reservation of that channel from MTR. The Current Track byte of the 
FST entry for this file is then examined. If this byte is zero, then 
this file has not previously been used. A half track assignment is 
requested from MTR: MTR returns a half track address to the requestor 
in byte one of the first word in the message buffer. If no half track 
is available, MTR will return a zero byte to the requestor: 2WD then 
inserts an error message in the dayfile and aborts the cmitrol point 
after dropping the channel reservation. 2WD now has the address of the 
half track where the next operation is to be performed, and proceeds 
to position the disk to this half track. This half track addressr.is 
compared with byte 2 of the TRT pointer word for this disk, and 
repositioning or head group selection performed only if required. Byte 
2 of the TRT pointer is then updated. 

2WD next requests another half track assignnient from MTR. This half 
track is a spare: by keeping it available, it is possible for 2WD to 
switch head groups within the group switch gap if this action should be 
required when the end of the current half track is reached. 

The transfer of data from the buffer to the, disk then begins. 2WD reads 
100 words from central memory into peripheral processor memory, sets 
control bytes one and two, and then writes the completed sector to the 
disk. As each sector is written, the number of the sector is examined 
to determine if the end of the half track is reached. To do this, 2WD 
compares the sector number with byte 4 of the TRT pointer word (if head 
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group number = 0-3) or byte 5 of the TRT pointer word (if head group 
number = 4-7). These bytes contain the values lOOg and 62g, respectively. 

If the end of the half track has been reached, 2WD positions the disk to 
the spare half track: again, the half track address, is compared with byte 
2 of the TKI pointer word and positioning or head group selection per- 
formed only if required. After initiating any repositioning which might 
be required, 2WD requests a spare half track from MTR. 

2WD continues reading lOOo-word blocks from central memory and writing 

o 

them to the disk__ until it recognizes that there is not enough data in 
the circular buffer for a complete sector. (Some part of a sector may 
still, however, remain.) 2T-7D then examines the buffer status contained 
in byte 5 of the FST entry to see if an end record was requested 
(2 bit =1). If an end record was requested, 2WD writes a short sector 
to the disk. If any data remained in the circular buffer, it will be 
written in this short sector: otherwise, control byte 2 will simply be 
set to zero. 

After the last data sector has been written to the disk, 2WD writes a 
file mark - a sector with both control bytes equal to zero. The Current 
Sector byte of the FST entry is not, however, incremented to reflect the 
writing of this file mark: the next write to this file will write over 
the file mark sector. After the file mark has been written, 2WD requests 
MTR to drop the spare half track assignment and to release the channel 
reservation. 

If no end record function v?as requested, 2WD simply updates the OUT 
pointer before returning control to CIO: There may still be some data 
in the circular buffer. If an end record function was requested, no 
data remains in the buffer: 2WD therefore sets IN = OUT = FIRST to 
indicate that the buffer is empty. 

When control is returned to CIO, CIO sets the 2 bit of the buffer 
status in the FST entry to 1 to indicate that the file is no longer in 
use, and sets the 2 bit of the buffer status in the calling program's 
argument list to 1 to indicate to the calling program that the operation 
has been completed. 
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The Disk Read Overlay, 2RD 

Disk read requests by users are executed by CIO's overlay 2RD'. This 
overlay is also used by IDJ and ITD. The processing performed by 2BP 
in this case is identical to that performed in the case of 2WD. On 
entry, 2RD reads the FST entry for the file, picks up txhe equipment number 
from byte one, and uses this number to obtain the EST entry. The channel 
number from the EST entry is then set in the I/O instructions. 

2KD then proceeds to compute the number of sectors which can be loaded 
into. the circular buffer. If there is not room for a full sector, control 
is returned to CIO. The data to be read may fit in the buffer in a 
contiguous block, or may wrap around the buffer. The computation of 
the values (total word count, total sector count, etc.) used in controlling 
the transfer of data to the buffer is performed in a manner similar to 
2WD. Again, the wraparound case is assumed. 

The Current Track byte of the FST entry is examined. If this byte is 
zero, the file has not been used before and so contains no data. 2SD 
sets the buffer status to indicate a file mark and returns control to 
CIO. 

2RD requests a channel reservation from MTR and positions the disk to 
the half track address contained in the FST entry's Current Track byte. 
As in all disk routines, the half track address is compared with the disk 
position specified in the TRT pointer, and repositioning or head group 
switching performed only if necessary. 

2iU3 then uses the Current Sector byte of the FST entry to construct the 
read function code, and reads the specified sector into peripheral 
processor memory. A status request is then issued, and the response 
is examined to determine if a parity error occurred. In the event of a 
parity error, the system rereads the sector three times; once using the 
normal sampling method and twice at 

varied sampling margins. If the parity error re-occurs in each of the 
rereads, 2RD inserts an error message in the dayfile and stops (via a 
UJN instruction). Since the halt occurs without the disk channel being 
released, all system activity will shortly cease (if this disk is the 
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system disk, disk 0). A dead start load will be necessary to reinitiate 
processing. 

If the read was successful, 2RD examines the high-order six bits of 
control byte one: if these bits are zero, then this control byte contains 
a sector number, v/hile if these bits are non-zero, this control byte 
. contains a half track number. In the latter case, 2RD positions the disk 
to the new half track address. While any repositioning or head group 
switching which might be required is in process, 2RD transfers the 
number of words specified in control byte 2 from peripheral processor 
memory to the circular buffer, and updates the values used in controlling 
the transfer. If the sector just read was a full sector (100„ CM words 
of data), and if there is enough room in the circular buffer for another 
full sector, 2RD loops to read the next sector from the disk. 

If the last sector read was a short sector, then the end of a logical 
record has been, reached, and the buffer status is set to reflect a 
record mark. If the end of logical record has been reached, or if there 
is not enough room in the circular buffer for a full sector, 2ED requests 
MTR to release the channel reservation, updates the IN pointer in the 
calling program's argument list, and returns control to CIO. CIO 
updates the buffer status in the FST entry to release the file reser- 
vation, and updates the buffer status in the calling program's argument 
list to indicate that the operation has been completed. 

If, after reading the last logical record in a file^ the calling program 
issues another read to the file, the file mark will be read. The pro- 
cessing proceeds as described above: 2RD reads a sector whose address is 
specified in the Current Track and Current Sector bytes of the FST entry. 
Since control byte 2 is zero, 2RD recognizes this as a short sector, sets 
the buffer status to reflect a record mark, and releases the channel. 
2RD then examines control byte one; since this contains zero, the file 
mark is recognized and the buffer status set accordingly before returning 
control to CIO. 
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The Backspace Disk Overlay. 2BD 

Disk backspacing may take the forni of a BCD backspace or, moire commonly, 
a binary backspace. In either case, it is desired to backspace over a 
logical record, and it is assumed that any backspacing over logical 
records in the buffer has been done by the calling program. Backspacing 
over the physical recordt; which may constitute a logical record is 
essentially a matter of backspacing over two sectors and then reading a 
sector, 

2BD uses a subroutine to backspace over a sector. (See flow chart on 
page A-5.) This subroutine examines the Current Sector byte of the FST 
entry, and, if non-zero, subtracts one from this number and exits. 
This is equivalent to backspacing over one physical record (i.e., one 
sector). If the Current Sector number is zero, then the preceding 
physical record is on another half track. In this case, the subroutine 
stores the Current Track byte from the EST entry for this file, since it 
will have to search the file for a sector which has this half track 
address contained in control byte one. 

The subroutine rewinds the file by picking up the Beginning Track byte 
from the FST entry. (Should the Beginning Track byte be equal to the 
Current Track byte, the subroutine exits, since this indicates that the 
system has backspaced over all physical records in this file.) After 
rewinding the file, the subroutine reads each sector in the file until 
it finds a sector with the desired half track address in control byte 
one. The- number of this sector is then stored, and control returned to 
the calling routine. A backspace operation on a file of any size may 
take considerable time if it should become necessary to rewind the file 
and search forward. 

A binary backspace on the disk consists of backspacing over two sectors 
(using the subroutine described above) and reading a sector until a 
short record is found, indicating the end of a logical record. 2BD sets 
the circular bu'ffer pointers IN and OUT equal to FIRST, and returns 
control to CIO. CIO updates the buffer status in the FST entry and in the 
calling program's argument list, before exiting. 
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Ic is also possible to issue a BCD bacl-.space to the disk. For the disk, 
as for 1" tape (but not for 1" tape), a logical BCD record consists of 
a series of central memory v/ords presumably containing display code data, 
terminated by a central memory whose lo\7-order byte (byte 5) is zero. 

The BCD backspace begins with the computation of the amount of data left 
in the buffer as a result of the last read. This quantity, referred to 
as D, is equal in IN-OUT if the data in the buffer is contiguous, or 
IN-OUT + LEIIT-FIRST if the data wraps around the buffer. This data was 
left in the buffer as a result of the last read, and may have been 
stored on the disk in several sectors. The system assumes that the 
calling program will backspace within the buffer, and so, before beginning 
a logical BCD record backspace on the disk, 2BD will backspace the 
disk a number of sectors .equivalent to the amount of data contained in 
the buffer. This quantity is represented by D. 

2BD therefore backspaces over a sector (by the same subroutine used in 
binary backspacing and described earlier) and reads that sector into 
peripheral processor memory. The sector length in control byte 2 is 
then compared with D: if less than D, then this sector is assumed to 
contain data which has already been read into the buffer. 2BD then 
decreases D by this amount, backspaces over this sector and the sector 
preceding it, and then reads a sector. The process of backspacing, 
reading, and reducing D is repeated until a sector is read whose length 
is greater than the present value of D: this sector could not entirely 
be part of the read data in the buffer, and so must be searched for a 
logical record. 2BD transfers this sector from peripheral processor 
memory to the circular buffer beginning at FIRST. If D is still non-zero, 
then part of this sector c.'.mtains data residing in the buffer at the time 
the backspace was requested, and presumably has been searched by the 
calling program: 2BD therefore sets the OUT pointer to FIRST + sector 
length - D. At the same time, the IN pointer is set to reflect the 
transfer of the sector to the buffer. 

2BD then searches each word in the buffer from OUT - 1 down to FIRST 
until a word with a' zero low-order byte is found, indicating the end of 
a logical BCD record. When the end of the record is found, 2BD updates 
the IN and OUT pointers in the calling program's argument list, and 
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returns control to CIO. OUT now points to the first v;ord following the 
end of the logical record. If no zero low-order byte was found, then 
2ED backspaces two sectors and reads one, and then repeats the buffer 
search. 

The Drop Track Overlay., 2DT 

When CIO receives a disk v;rite request, it first calls the 2BP overlay 
to check the legality of the buffer parameters and to search the FNT for 
the file naine. CIO then reads the EST entry for this file, and examines 
the buffer status in byte 5. If the buffer status indicates that the 
last operation performed on this file was a read operation, then an 
overlay, 2DT, is called to drop the subsequent portion of the file. In 
effect, then, if some part of a file is read and it is then decided to 
write to that file, the remainder of the file is erased. 

The flow chart for the 2DT overlay is shown on page A-3 of the attached 
flci\-; charts. The routine picks up the Current Track byte and Current 
Sector byte from the FST entry for the file, and reads the sector at this 
address. If this sector is a file mark, 2DT returns control to CIO. 
If control byte one of this sector contains a half track address, 2DT 
requests MTR to drop this half track reservation. MTR then clears the 
bit in the Track Reservation Table corresponding to this half track 
address. 2DT positions the disk to this half track address and begins 
reading sectors until a file mark is found or the end of the half 
track is reached. The process of reading and dropping half tracks 
continues until the end of the file is reached. 

At the end of a job, all local files associated with the job are 
dropped. For disk files, a process similar to that described above is 
required to release iTalf track reservations. This is performed for 
lAJ by the 2DF overlay. 2DF differs from 2DT in that 2DF drops files 
assigned to other equipment as well as those assigned to the disk, and 
2DF drops all the half tracks reserved by a file, not just those following 
the half track specified in the Current Track byte of the FST entry. 
2DF is also called by IDJ and ITD when printing files or writing files 
on tape. 
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